Skip to content
This repository was archived by the owner on Jul 10, 2024. It is now read-only.

Commit 147f8fa

Browse files
committed
v0.7.13
1 parent f22efb1 commit 147f8fa

File tree

6 files changed

+43
-43
lines changed

6 files changed

+43
-43
lines changed

Diff for: README.md

+1-1
Original file line numberDiff line numberDiff line change
@@ -26,7 +26,7 @@ Click Install to see a live preview of Offline on your website.
2626
Manual Installation
2727
-------------------
2828

29-
Include [the javascript](https://raw.github.com/HubSpot/offline/v0.7.11/offline.min.js), one of [the themes](http://github.hubspot.com/offline/docs/welcome/), and one of [the
29+
Include [the javascript](https://raw.github.com/HubSpot/offline/v0.7.13/offline.min.js), one of [the themes](http://github.hubspot.com/offline/docs/welcome/), and one of [the
3030
languages](https://github.com/HubSpot/offline/tree/master/themes) on your site. You're done!
3131

3232
To use only the JavaScript API without a UI indicator, simply leave out the CSS file.

Diff for: bower.json

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
{
22
"name": "offline",
3-
"version": "0.7.12",
3+
"version": "0.7.13",
44
"homepage": "http://github.hubspot.com/offline/docs/welcome",
55
"authors": [
66
"Zack Bloom <zackbloom@gmail.com>",

Diff for: docs/welcome/index.html

+1-1
Original file line numberDiff line numberDiff line change
@@ -355,7 +355,7 @@ <h2>Install</h2>
355355
<br/>
356356
<br/>
357357
<h2>Download</h2>
358-
<p><a class="button" href="https://raw.github.com/HubSpot/offline/v0.7.11/offline.min.js">Offline.js</a></p>
358+
<p><a class="button" href="https://raw.github.com/HubSpot/offline/v0.7.13/offline.min.js">Offline.js</a></p>
359359
<br/>
360360
<h2>Pick a Theme</h2>
361361
<div class="themes full-themes"></div>

Diff for: offline.js

+38-38
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
/*! offline-js 0.7.12 */
1+
/*! offline-js 0.7.13 */
22
(function() {
33
var Offline, checkXHR, defaultOptions, extendNative, grab, handlers, init;
44
extendNative = function(to, from) {
@@ -30,22 +30,22 @@
3030
reconnect:!0
3131
}, grab = function(obj, key) {
3232
var cur, i, j, len, part, parts;
33-
for (cur = obj, parts = key.split("."), i = j = 0, len = parts.length; len > j && (part = parts[i],
33+
for (cur = obj, parts = key.split("."), i = j = 0, len = parts.length; len > j && (part = parts[i],
3434
cur = cur[part], "object" == typeof cur); i = ++j) ;
3535
return i === parts.length - 1 ? cur :void 0;
3636
}, Offline.getOption = function(key) {
3737
var ref, val;
38-
return val = null != (ref = grab(Offline.options, key)) ? ref :grab(defaultOptions, key),
38+
return val = null != (ref = grab(Offline.options, key)) ? ref :grab(defaultOptions, key),
3939
"function" == typeof val ? val() :val;
4040
}, "function" == typeof window.addEventListener && window.addEventListener("online", function() {
4141
return setTimeout(Offline.confirmUp, 100);
4242
}, !1), "function" == typeof window.addEventListener && window.addEventListener("offline", function() {
4343
return Offline.confirmDown();
4444
}, !1), Offline.state = "up", Offline.markUp = function() {
45-
return Offline.trigger("confirmed-up"), "up" !== Offline.state ? (Offline.state = "up",
45+
return Offline.trigger("confirmed-up"), "up" !== Offline.state ? (Offline.state = "up",
4646
Offline.trigger("up")) :void 0;
4747
}, Offline.markDown = function() {
48-
return Offline.trigger("confirmed-down"), "down" !== Offline.state ? (Offline.state = "down",
48+
return Offline.trigger("confirmed-down"), "down" !== Offline.state ? (Offline.state = "down",
4949
Offline.trigger("down")) :void 0;
5050
}, handlers = {}, Offline.on = function(event, handler, ctx) {
5151
var e, events, j, len, results;
@@ -58,7 +58,7 @@
5858
var _handler, ctx, i, ref, results;
5959
if (null != handlers[event]) {
6060
if (handler) {
61-
for (i = 0, results = []; i < handlers[event].length; ) ref = handlers[event][i],
61+
for (i = 0, results = []; i < handlers[event].length; ) ref = handlers[event][i],
6262
ctx = ref[0], _handler = ref[1], _handler === handler ? results.push(handlers[event].splice(i, 1)) :results.push(i++);
6363
return results;
6464
}
@@ -67,7 +67,7 @@
6767
}, Offline.trigger = function(event) {
6868
var ctx, handler, j, len, ref, ref1, results;
6969
if (null != handlers[event]) {
70-
for (ref = handlers[event], results = [], j = 0, len = ref.length; len > j; j++) ref1 = ref[j],
70+
for (ref = handlers[event], results = [], j = 0, len = ref.length; len > j; j++) ref1 = ref[j],
7171
ctx = ref1[0], handler = ref1[1], results.push(handler.call(ctx));
7272
return results;
7373
}
@@ -86,8 +86,8 @@
8686
});
8787
}, Offline.checks = {}, Offline.checks.xhr = function() {
8888
var e, xhr;
89-
xhr = new XMLHttpRequest(), xhr.offline = !1, xhr.open("HEAD", Offline.getOption("checks.xhr.url"), !0),
90-
null != xhr.timeout && (xhr.timeout = Offline.getOption("checks.xhr.timeout")),
89+
xhr = new XMLHttpRequest(), xhr.offline = !1, xhr.open("HEAD", Offline.getOption("checks.xhr.url"), !0),
90+
null != xhr.timeout && (xhr.timeout = Offline.getOption("checks.xhr.timeout")),
9191
checkXHR(xhr, Offline.markUp, Offline.markDown);
9292
try {
9393
xhr.send();
@@ -97,7 +97,7 @@
9797
return xhr;
9898
}, Offline.checks.image = function() {
9999
var img;
100-
return img = document.createElement("img"), img.onerror = Offline.markDown, img.onload = Offline.markUp,
100+
return img = document.createElement("img"), img.onerror = Offline.markDown, img.onload = Offline.markUp,
101101
void (img.src = Offline.getOption("checks.image.url"));
102102
}, Offline.checks.down = Offline.markDown, Offline.checks.up = Offline.markUp, Offline.check = function() {
103103
return Offline.trigger("checking"), Offline.checks[Offline.getOption("checks.active")]();
@@ -118,13 +118,13 @@
118118
};
119119
}, _XMLHttpRequest = window.XMLHttpRequest, window.XMLHttpRequest = function(flags) {
120120
var _overrideMimeType, _setRequestHeader, req;
121-
return req = new _XMLHttpRequest(flags), monitorXHR(req, flags), _setRequestHeader = req.setRequestHeader,
121+
return req = new _XMLHttpRequest(flags), monitorXHR(req, flags), _setRequestHeader = req.setRequestHeader,
122122
req.headers = {}, req.setRequestHeader = function(name, value) {
123123
return req.headers[name] = value, _setRequestHeader.call(req, name, value);
124124
}, _overrideMimeType = req.overrideMimeType, req.overrideMimeType = function(type) {
125125
return req.mimeType = type, _overrideMimeType.call(req, type);
126126
}, req;
127-
}, extendNative(window.XMLHttpRequest, _XMLHttpRequest), null != window.XDomainRequest ? (_XDomainRequest = window.XDomainRequest,
127+
}, extendNative(window.XMLHttpRequest, _XMLHttpRequest), null != window.XDomainRequest ? (_XDomainRequest = window.XDomainRequest,
128128
window.XDomainRequest = function() {
129129
var req;
130130
return req = new _XDomainRequest(), monitorXHR(req), req;
@@ -140,45 +140,45 @@
140140
if (!window.Offline) throw new Error("Offline Reconnect brought in without offline.js");
141141
rc = Offline.reconnect = {}, retryIntv = null, reset = function() {
142142
var ref;
143-
return null != rc.state && "inactive" !== rc.state && Offline.trigger("reconnect:stopped"),
143+
return null != rc.state && "inactive" !== rc.state && Offline.trigger("reconnect:stopped"),
144144
rc.state = "inactive", rc.remaining = rc.delay = null != (ref = Offline.getOption("reconnect.initialDelay")) ? ref :3;
145145
}, next = function() {
146146
var delay, ref;
147-
return delay = null != (ref = Offline.getOption("reconnect.delay")) ? ref :Math.min(Math.ceil(1.5 * rc.delay), 3600),
147+
return delay = null != (ref = Offline.getOption("reconnect.delay")) ? ref :Math.min(Math.ceil(1.5 * rc.delay), 3600),
148148
rc.remaining = rc.delay = delay;
149149
}, tick = function() {
150-
return "connecting" !== rc.state ? (rc.remaining -= 1, Offline.trigger("reconnect:tick"),
150+
return "connecting" !== rc.state ? (rc.remaining -= 1, Offline.trigger("reconnect:tick"),
151151
0 === rc.remaining ? tryNow() :void 0) :void 0;
152152
}, tryNow = function() {
153-
return "waiting" === rc.state ? (Offline.trigger("reconnect:connecting"), rc.state = "connecting",
153+
return "waiting" === rc.state ? (Offline.trigger("reconnect:connecting"), rc.state = "connecting",
154154
Offline.check()) :void 0;
155155
}, down = function() {
156-
return Offline.getOption("reconnect") ? (reset(), rc.state = "waiting", Offline.trigger("reconnect:started"),
156+
return Offline.getOption("reconnect") ? (reset(), rc.state = "waiting", Offline.trigger("reconnect:started"),
157157
retryIntv = setInterval(tick, 1e3)) :void 0;
158158
}, up = function() {
159159
return null != retryIntv && clearInterval(retryIntv), reset();
160160
}, nope = function() {
161-
return Offline.getOption("reconnect") && "connecting" === rc.state ? (Offline.trigger("reconnect:failure"),
161+
return Offline.getOption("reconnect") && "connecting" === rc.state ? (Offline.trigger("reconnect:failure"),
162162
rc.state = "waiting", next()) :void 0;
163-
}, rc.tryNow = tryNow, reset(), Offline.on("down", down), Offline.on("confirmed-down", nope),
163+
}, rc.tryNow = tryNow, reset(), Offline.on("down", down), Offline.on("confirmed-down", nope),
164164
Offline.on("up", up);
165165
}.call(this), function() {
166166
var clear, flush, held, holdRequest, makeRequest, waitingOnConfirm;
167167
if (!window.Offline) throw new Error("Requests module brought in without offline.js");
168168
held = [], waitingOnConfirm = !1, holdRequest = function(req) {
169-
return Offline.trigger("requests:capture"), "down" !== Offline.state && (waitingOnConfirm = !0),
169+
return Offline.trigger("requests:capture"), "down" !== Offline.state && (waitingOnConfirm = !0),
170170
held.push(req);
171171
}, makeRequest = function(arg) {
172172
var body, name, password, ref, type, url, user, val, xhr;
173-
xhr = arg.xhr, url = arg.url, type = arg.type, user = arg.user, password = arg.password,
173+
xhr = arg.xhr, url = arg.url, type = arg.type, user = arg.user, password = arg.password,
174174
body = arg.body, xhr.abort(), xhr.open(type, url, !0, user, password), ref = xhr.headers;
175175
for (name in ref) val = ref[name], xhr.setRequestHeader(name, val);
176176
return xhr.mimeType && xhr.overrideMimeType(xhr.mimeType), xhr.send(body);
177177
}, clear = function() {
178178
return held = [];
179179
}, flush = function() {
180180
var i, key, len, request, requests, url;
181-
for (Offline.trigger("requests:flush"), requests = {}, i = 0, len = held.length; len > i; i++) request = held[i],
181+
for (Offline.trigger("requests:flush"), requests = {}, i = 0, len = held.length; len > i; i++) request = held[i],
182182
url = request.url.replace(/(\?|&)_=[0-9]+/, function(match, char) {
183183
return "?" === char ? char :"";
184184
}), requests[request.type.toUpperCase() + " - " + url] = request;
@@ -195,10 +195,10 @@
195195
return holdRequest(request);
196196
}, _send = xhr.send, xhr.send = function(body) {
197197
return request.body = body, _send.apply(xhr, arguments);
198-
}, async) ? null === xhr.onprogress ? (xhr.addEventListener("error", hold, !1),
199-
xhr.addEventListener("timeout", hold, !1)) :(_onreadystatechange = xhr.onreadystatechange,
198+
}, async) ? null === xhr.onprogress ? (xhr.addEventListener("error", hold, !1),
199+
xhr.addEventListener("timeout", hold, !1)) :(_onreadystatechange = xhr.onreadystatechange,
200200
xhr.onreadystatechange = function() {
201-
return 0 === xhr.readyState ? hold() :4 === xhr.readyState && (0 === xhr.status || xhr.status >= 12e3) && hold(),
201+
return 0 === xhr.readyState ? hold() :4 === xhr.readyState && (0 === xhr.status || xhr.status >= 12e3) && hold(),
202202
"function" == typeof _onreadystatechange ? _onreadystatechange.apply(null, arguments) :void 0;
203203
}) :void 0;
204204
}), Offline.requests = {
@@ -209,13 +209,13 @@
209209
}.call(this), function() {
210210
var base, i, len, ref, state;
211211
if (!Offline) throw new Error("Offline simulate brought in without offline.js");
212-
for (ref = [ "up", "down" ], i = 0, len = ref.length; len > i; i++) state = ref[i],
213-
(document.querySelector("script[data-simulate='" + state + "']") || localStorage.OFFLINE_SIMULATE === state) && (null == Offline.options && (Offline.options = {}),
212+
for (ref = [ "up", "down" ], i = 0, len = ref.length; len > i; i++) state = ref[i],
213+
(document.querySelector("script[data-simulate='" + state + "']") || localStorage.OFFLINE_SIMULATE === state) && (null == Offline.options && (Offline.options = {}),
214214
null == (base = Offline.options).checks && (base.checks = {}), Offline.options.checks.active = state);
215215
}.call(this), function() {
216216
var RETRY_TEMPLATE, TEMPLATE, _onreadystatechange, addClass, content, createFromHTML, el, flashClass, flashTimeouts, init, removeClass, render, roundTime;
217217
if (!window.Offline) throw new Error("Offline UI brought in without offline.js");
218-
TEMPLATE = '<div class="offline-ui"><div class="offline-ui-content"></div></div>',
218+
TEMPLATE = '<div class="offline-ui"><div class="offline-ui-content"></div></div>',
219219
RETRY_TEMPLATE = '<a href class="offline-ui-retry"></a>', createFromHTML = function(html) {
220220
var el;
221221
return el = document.createElement("div"), el.innerHTML = html, el.children[0];
@@ -224,7 +224,7 @@
224224
}, removeClass = function(name) {
225225
return el.className = el.className.replace(new RegExp("(^| )" + name.split(" ").join("|") + "( |$)", "gi"), " ");
226226
}, flashTimeouts = {}, flashClass = function(name, time) {
227-
return addClass(name), null != flashTimeouts[name] && clearTimeout(flashTimeouts[name]),
227+
return addClass(name), null != flashTimeouts[name] && clearTimeout(flashTimeouts[name]),
228228
flashTimeouts[name] = setTimeout(function() {
229229
return removeClass(name), delete flashTimeouts[name];
230230
}, 1e3 * time);
@@ -236,39 +236,39 @@
236236
minute:60,
237237
second:1
238238
};
239-
for (unit in units) if (mult = units[unit], sec >= mult) return val = Math.floor(sec / mult),
239+
for (unit in units) if (mult = units[unit], sec >= mult) return val = Math.floor(sec / mult),
240240
[ val, unit ];
241241
return [ "now", "" ];
242242
}, render = function() {
243243
var button, handler;
244-
return el = createFromHTML(TEMPLATE), document.body.appendChild(el), null != Offline.reconnect && Offline.getOption("reconnect") && (el.appendChild(createFromHTML(RETRY_TEMPLATE)),
244+
return el = createFromHTML(TEMPLATE), document.body.appendChild(el), null != Offline.reconnect && Offline.getOption("reconnect") && (el.appendChild(createFromHTML(RETRY_TEMPLATE)),
245245
button = el.querySelector(".offline-ui-retry"), handler = function(e) {
246246
return e.preventDefault(), Offline.reconnect.tryNow();
247-
}, null != button.addEventListener ? button.addEventListener("click", handler, !1) :button.attachEvent("click", handler)),
247+
}, null != button.addEventListener ? button.addEventListener("click", handler, !1) :button.attachEvent("click", handler)),
248248
addClass("offline-ui-" + Offline.state), content = el.querySelector(".offline-ui-content");
249249
}, init = function() {
250250
return render(), Offline.on("up", function() {
251-
return removeClass("offline-ui-down"), addClass("offline-ui-up"), flashClass("offline-ui-up-2s", 2),
251+
return removeClass("offline-ui-down"), addClass("offline-ui-up"), flashClass("offline-ui-up-2s", 2),
252252
flashClass("offline-ui-up-5s", 5);
253253
}), Offline.on("down", function() {
254-
return removeClass("offline-ui-up"), addClass("offline-ui-down"), flashClass("offline-ui-down-2s", 2),
254+
return removeClass("offline-ui-up"), addClass("offline-ui-down"), flashClass("offline-ui-down-2s", 2),
255255
flashClass("offline-ui-down-5s", 5);
256256
}), Offline.on("reconnect:connecting", function() {
257257
return addClass("offline-ui-connecting"), removeClass("offline-ui-waiting");
258258
}), Offline.on("reconnect:tick", function() {
259259
var ref, time, unit;
260-
return addClass("offline-ui-waiting"), removeClass("offline-ui-connecting"), ref = roundTime(Offline.reconnect.remaining),
261-
time = ref[0], unit = ref[1], content.setAttribute("data-retry-in-value", time),
260+
return addClass("offline-ui-waiting"), removeClass("offline-ui-connecting"), ref = roundTime(Offline.reconnect.remaining),
261+
time = ref[0], unit = ref[1], content.setAttribute("data-retry-in-value", time),
262262
content.setAttribute("data-retry-in-unit", unit);
263263
}), Offline.on("reconnect:stopped", function() {
264-
return removeClass("offline-ui-connecting offline-ui-waiting"), content.setAttribute("data-retry-in-value", null),
264+
return removeClass("offline-ui-connecting offline-ui-waiting"), content.setAttribute("data-retry-in-value", null),
265265
content.setAttribute("data-retry-in-unit", null);
266266
}), Offline.on("reconnect:failure", function() {
267267
return flashClass("offline-ui-reconnect-failed-2s", 2), flashClass("offline-ui-reconnect-failed-5s", 5);
268268
}), Offline.on("reconnect:success", function() {
269269
return flashClass("offline-ui-reconnect-succeeded-2s", 2), flashClass("offline-ui-reconnect-succeeded-5s", 5);
270270
});
271-
}, "complete" === document.readyState ? init() :null != document.addEventListener ? document.addEventListener("DOMContentLoaded", init, !1) :(_onreadystatechange = document.onreadystatechange,
271+
}, "complete" === document.readyState ? init() :null != document.addEventListener ? document.addEventListener("DOMContentLoaded", init, !1) :(_onreadystatechange = document.onreadystatechange,
272272
document.onreadystatechange = function() {
273273
return "complete" === document.readyState && init(), "function" == typeof _onreadystatechange ? _onreadystatechange.apply(null, arguments) :void 0;
274274
});

0 commit comments

Comments
 (0)