Update intercooler.js

This commit is contained in:
Jason McBrayer 2020-07-08 13:24:00 -04:00
parent adc65f8d5a
commit 012c0b74c1
1 changed files with 244 additions and 115 deletions

View File

@ -4,7 +4,7 @@
define(["jquery"], function (a0) { define(["jquery"], function (a0) {
return (root['Intercooler'] = factory(a0)); return (root['Intercooler'] = factory(a0));
}); });
} else if (typeof exports === 'object') { } else if (typeof module === 'object' && module.exports) {
// Node. Does not work with strict CommonJS, but // Node. Does not work with strict CommonJS, but
// only CommonJS-like environments that support module.exports, // only CommonJS-like environments that support module.exports,
// like Node. // like Node.
@ -24,7 +24,7 @@ var Intercooler = Intercooler || (function() {
// work around zepto build issue TODO - fix me // work around zepto build issue TODO - fix me
if((typeof Zepto !== "undefined") && ($ == null)) { if((typeof Zepto !== "undefined") && ($ == null)) {
$ = Zepto window["$"] = Zepto
} }
//-------------------------------------------------- //--------------------------------------------------
@ -68,7 +68,7 @@ var Intercooler = Intercooler || (function() {
return false; return false;
} }
return adest.slice(0, asrc.length).join("/") == asrc.join("/") || return adest.slice(0, asrc.length).join("/") == asrc.join("/") ||
asrc.slice(0, adest.length).join("/") == adest.join("/"); asrc.slice(0, adest.length).join("/") == adest.join("/");
}; };
//============================================================ //============================================================
@ -88,9 +88,10 @@ var Intercooler = Intercooler || (function() {
} }
function hideIndicator(elt) { function hideIndicator(elt) {
if (elt.data('ic-use-transition')) { if (elt.data('ic-use-transition') || elt.data('ic-indicator-cleared')) {
elt.data('ic-use-transition', null); elt.data('ic-use-transition', null);
elt.addClass('ic-use-transition'); elt.addClass('ic-use-transition');
elt.data('ic-indicator-cleared', true);
} else { } else {
elt.hide(); elt.hide();
} }
@ -259,6 +260,11 @@ var Intercooler = Intercooler || (function() {
document.title = xhr.getResponseHeader("X-IC-Title"); document.title = xhr.getResponseHeader("X-IC-Title");
} }
if (xhr.getResponseHeader("X-IC-Title-Encoded")) {
var decodedTitle = decodeURIComponent((xhr.getResponseHeader("X-IC-Title-Encoded")).replace(/\+/g, '%20'));
document.title = decodedTitle;
}
if (xhr.getResponseHeader("X-IC-Refresh")) { if (xhr.getResponseHeader("X-IC-Refresh")) {
var pathsToRefresh = xhr.getResponseHeader("X-IC-Refresh").split(","); var pathsToRefresh = xhr.getResponseHeader("X-IC-Refresh").split(",");
log(elt, "X-IC-Refresh: refreshing " + pathsToRefresh, "DEBUG"); log(elt, "X-IC-Refresh: refreshing " + pathsToRefresh, "DEBUG");
@ -351,14 +357,19 @@ var Intercooler = Intercooler || (function() {
function beforeRequest(elt) { function beforeRequest(elt) {
elt.addClass('disabled'); elt.addClass('disabled');
elt.addClass('ic-request-in-flight');
elt.data('ic-request-in-flight', true); elt.data('ic-request-in-flight', true);
} }
function requestCleanup(indicator, elt) { function requestCleanup(indicator, globalIndicator, elt) {
if (indicator.length > 0) { if (indicator.length > 0) {
hideIndicator(indicator); hideIndicator(indicator);
} }
if (globalIndicator.length > 0) {
hideIndicator(globalIndicator);
}
elt.removeClass('disabled'); elt.removeClass('disabled');
elt.removeClass('ic-request-in-flight');
elt.data('ic-request-in-flight', false); elt.data('ic-request-in-flight', false);
if (elt.data('ic-next-request')) { if (elt.data('ic-next-request')) {
elt.data('ic-next-request')["req"](); elt.data('ic-next-request')["req"]();
@ -404,19 +415,19 @@ var Intercooler = Intercooler || (function() {
var names = []; var names = [];
var values = []; var values = [];
if (args) { if (args) {
for (var i = 0; i < args.length; i++) { for (var i = 0; i < args.length; i++) {
names.push(args[i][0]); names.push(args[i][0]);
values.push(args[i][1]); values.push(args[i][1]);
} }
} }
if (isIdentifier(script)) { if (isIdentifier(script)) {
return window[script].apply(this, values); return window[script].apply(this, values);
} else { } else {
var outerfunc = window["eval"].call( var outerfunc = window["eval"].call(
window, window,
'(function (' + names.join(", ") + ') {' + script + '})' '(function (' + names.join(", ") + ') {' + script + '})'
); );
return outerfunc.apply(this, values); return outerfunc.apply(this, values);
} }
} }
@ -439,12 +450,35 @@ var Intercooler = Intercooler || (function() {
return msg; return msg;
} }
function getLocalURL(baseURL, paramsToPush, data) {
if (paramsToPush) {
baseURL = baseURL + "?";
var vars = {};
data.replace(/([^=&]+)=([^&]*)/gi, function(m,key,value) {
vars[key] = value;
});
$(paramsToPush.split(",")).each(function(index) {
var param = $.trim(this);
var value = vars[param] || "";
baseURL += (index == 0) ? "" : "&";
baseURL += param + "=" + value;
});
}
return baseURL;
}
function handleRemoteRequest(elt, type, url, data, success) { function handleRemoteRequest(elt, type, url, data, success) {
beforeRequest(elt); beforeRequest(elt);
data = replaceOrAddMethod(data, type); data = replaceOrAddMethod(data, type);
// Global spinner support
var globalIndicator = findGlobalIndicator(elt);
if (globalIndicator && globalIndicator.length > 0) {
showIndicator(globalIndicator);
}
// Spinner support // Spinner support
var indicator = findIndicator(elt); var indicator = findIndicator(elt);
if (indicator.length > 0) { if (indicator.length > 0) {
@ -479,17 +513,18 @@ var Intercooler = Intercooler || (function() {
} }
maybeInvokeLocalAction(elt, "-beforeSend"); maybeInvokeLocalAction(elt, "-beforeSend");
}, },
success: function(data, textStatus, xhr) { success: function(responseData, textStatus, xhr) {
triggerEvent(elt, "success.ic", [elt, data, textStatus, xhr, requestId]); triggerEvent(elt, "success.ic", [elt, responseData, textStatus, xhr, requestId]);
log(elt, "AJAX request " + requestId + " was successful.", "DEBUG"); log(elt, "AJAX request " + requestId + " was successful.", "DEBUG");
var onSuccess = closestAttrValue(elt, 'ic-on-success'); var onSuccess = closestAttrValue(elt, 'ic-on-success');
if (onSuccess) { if (onSuccess) {
if (globalEval(onSuccess, [["elt", elt], ["data", data], ["textStatus", textStatus], ["xhr", xhr]]) == false) { if (globalEval(onSuccess, [["elt", elt], ["data", responseData], ["textStatus", textStatus], ["xhr", xhr]]) == false) {
return; return;
} }
} }
var beforeHeaders = new Date(); var beforeHeaders = new Date();
var oldTitle = document.title;
try { try {
if (processHeaders(elt, xhr)) { if (processHeaders(elt, xhr)) {
log(elt, "Processed headers for request " + requestId + " in " + (new Date() - beforeHeaders) + "ms", "DEBUG"); log(elt, "Processed headers for request " + requestId + " in " + (new Date() - beforeHeaders) + "ms", "DEBUG");
@ -497,10 +532,12 @@ var Intercooler = Intercooler || (function() {
if (xhr.getResponseHeader("X-IC-PushURL") || closestAttrValue(elt, 'ic-push-url') == "true") { if (xhr.getResponseHeader("X-IC-PushURL") || closestAttrValue(elt, 'ic-push-url') == "true") {
try { try {
requestCleanup(indicator, elt); // clean up before snap-shotting HTML requestCleanup(indicator, globalIndicator, elt); // clean up before snap-shotting HTML
var newUrl = xhr.getResponseHeader("X-IC-PushURL") || closestAttrValue(elt, 'ic-src'); var baseURL = closestAttrValue(elt, 'ic-src');
var paramsToPush = closestAttrValue(elt, 'ic-push-params');
var newUrl = xhr.getResponseHeader("X-IC-PushURL") || getLocalURL(baseURL, paramsToPush, data);
if(_history) { if(_history) {
_history.snapshotForHistory(newUrl); _history.snapshotForHistory(newUrl, oldTitle);
} else { } else {
throw "History support not enabled"; throw "History support not enabled";
} }
@ -509,11 +546,11 @@ var Intercooler = Intercooler || (function() {
} }
} }
success(data, textStatus, elt, xhr); success(responseData, textStatus, elt, xhr);
log(elt, "Process content for request " + requestId + " in " + (new Date() - beforeSuccess) + "ms", "DEBUG"); log(elt, "Process content for request " + requestId + " in " + (new Date() - beforeSuccess) + "ms", "DEBUG");
} }
triggerEvent(elt, "after.success.ic", [elt, data, textStatus, xhr, requestId]); triggerEvent(elt, "after.success.ic", [elt, responseData, textStatus, xhr, requestId]);
maybeInvokeLocalAction(elt, "-success"); maybeInvokeLocalAction(elt, "-success");
} catch (e) { } catch (e) {
log(elt, "Error processing successful request " + requestId + " : " + formatError(e), "ERROR"); log(elt, "Error processing successful request " + requestId + " : " + formatError(e), "ERROR");
@ -531,7 +568,7 @@ var Intercooler = Intercooler || (function() {
}, },
complete: function(xhr, status) { complete: function(xhr, status) {
log(elt, "AJAX request " + requestId + " completed in " + (new Date() - requestStart) + "ms", "DEBUG"); log(elt, "AJAX request " + requestId + " completed in " + (new Date() - requestStart) + "ms", "DEBUG");
requestCleanup(indicator, elt); requestCleanup(indicator, globalIndicator, elt);
try { try {
if ($.contains(document, elt[0])) { if ($.contains(document, elt[0])) {
triggerEvent(elt, "complete.ic", [elt, data, status, xhr, requestId]); triggerEvent(elt, "complete.ic", [elt, data, status, xhr, requestId]);
@ -557,14 +594,24 @@ var Intercooler = Intercooler || (function() {
triggerEvent($(document), "beforeAjaxSend.ic", [ajaxSetup, elt]); triggerEvent($(document), "beforeAjaxSend.ic", [ajaxSetup, elt]);
if(ajaxSetup.cancel) { if(ajaxSetup.cancel) {
requestCleanup(indicator, elt); requestCleanup(indicator, globalIndicator, elt);
} else { } else {
$.ajax(ajaxSetup) $.ajax(ajaxSetup)
} }
} }
function findGlobalIndicator(elt) {
var indicator = $([]);
elt = $(elt);
var attr = closestAttrValue(elt, 'ic-global-indicator');
if (attr && attr !== "false") {
indicator = $(attr).first();
}
return indicator;
}
function findIndicator(elt) { function findIndicator(elt) {
var indicator = null; var indicator = $([]);
elt = $(elt); elt = $(elt);
if (getICAttribute(elt, 'ic-indicator')) { if (getICAttribute(elt, 'ic-indicator')) {
indicator = $(getICAttribute(elt, 'ic-indicator')).first(); indicator = $(getICAttribute(elt, 'ic-indicator')).first();
@ -612,14 +659,14 @@ var Intercooler = Intercooler || (function() {
return data; return data;
} }
function appendData(data, string, value) { function appendData(data, key, value) {
if ($.type(data) === "string") { if ($.type(data) === "string") {
if($.type(value) !== "string") { if($.type(value) !== "string") {
value = JSON.stringify(value); value = JSON.stringify(value);
} }
return data + "&" + string + "=" + encodeURIComponent(value); return data + "&" + key + "=" + encodeURIComponent(value);
} else { } else {
data.append(string, value); data.append(key, value);
return data; return data;
} }
} }
@ -727,6 +774,7 @@ var Intercooler = Intercooler || (function() {
}); });
} else { } else {
processMacros(elt); processMacros(elt);
processEnhancement(elt);
processSources(elt); processSources(elt);
processPolling(elt); processPolling(elt);
processEventSources(elt); processEventSources(elt);
@ -846,6 +894,18 @@ var Intercooler = Intercooler || (function() {
} }
} }
function processEnhancement(elt) {
if (elt.closest('.ic-ignore').length == 0) {
if(closestAttrValue(elt, 'ic-enhance') === 'true') {
enhanceDomTree(elt);
} else {
elt.find(getICAttributeSelector('ic-enhance')).each(function(){
enhanceDomTree($(this));
});
}
}
}
function processEventSources(elt) { function processEventSources(elt) {
if (elt.closest('.ic-ignore').length == 0) { if (elt.closest('.ic-ignore').length == 0) {
handleEventSource(elt); handleEventSource(elt);
@ -1024,14 +1084,15 @@ var Intercooler = Intercooler || (function() {
elt = $(elt); elt = $(elt);
if (getICAttribute(elt, 'ic-sse-src')) { if (getICAttribute(elt, 'ic-sse-src')) {
var evtSrcUrl = getICAttribute(elt, 'ic-sse-src'); var evtSrcUrl = getICAttribute(elt, 'ic-sse-src');
var eventSource = initEventSource(elt, evtSrcUrl); var evtSrcWithCredentials = getICAttribute(elt, 'ic-sse-with-credentials') === 'true';
var eventSource = initEventSource(elt, evtSrcUrl, evtSrcWithCredentials);
elt.data('ic-event-sse-source', eventSource); elt.data('ic-event-sse-source', eventSource);
elt.data('ic-event-sse-map', {}); elt.data('ic-event-sse-map', {});
} }
} }
function initEventSource(elt, evtSrcUrl) { function initEventSource(elt, evtSrcUrl, evtSrcWithCredentials) {
var eventSource = Intercooler._internal.initEventSource(evtSrcUrl); var eventSource = Intercooler._internal.initEventSource(evtSrcUrl, evtSrcWithCredentials);
eventSource.onmessage = function(e) { eventSource.onmessage = function(e) {
processICResponse(e.data, elt, false); processICResponse(e.data, elt, false);
}; };
@ -1069,7 +1130,9 @@ var Intercooler = Intercooler || (function() {
} }
function handleTriggerOn(elt) { function handleTriggerOn(elt) {
if (getICAttribute(elt, 'ic-trigger-on')) {
var triggerOnValue = getICAttribute(elt, 'ic-trigger-on');
if (triggerOnValue) {
// record button or submit input click info // record button or submit input click info
if(elt.is('form')) { if(elt.is('form')) {
elt.on('click focus', 'input, button, select, textarea', function(e){ elt.on('click focus', 'input, button, select, textarea', function(e){
@ -1080,59 +1143,65 @@ var Intercooler = Intercooler || (function() {
} }
}); });
} }
if (getICAttribute(elt, 'ic-trigger-on') == 'load') { var triggerOnArray = triggerOnValue.split(",");
fireICRequest(elt); for (var i = 0; i < triggerOnArray.length; i++) {
} else if (getICAttribute(elt, 'ic-trigger-on') == 'scrolled-into-view') { var triggerOn = $.trim(triggerOnArray[i]);
initScrollHandler(); var splitTriggerOn = triggerOn.split(" ");
setTimeout(function() { var eventString = eventFor(splitTriggerOn[0], $(elt));
triggerEvent($(window), 'scroll'); var eventModifier = splitTriggerOn[1];
}, 100); // Trigger a scroll in case element is already viewable
} else { if (triggerOn == 'load') {
var triggerOn = getICAttribute(elt, 'ic-trigger-on').split(" "); fireICRequest(elt);
if(triggerOn[0].indexOf("sse:") == 0) { } else if (triggerOn == 'scrolled-into-view') {
//Server-sent event, find closest event source and register for it initScrollHandler();
var sourceElt = elt.closest(getICAttributeSelector('ic-sse-src')); setTimeout(function() {
if(sourceElt) { triggerEvent($(window), 'scroll');
registerSSE(sourceElt, triggerOn[0].substr(4)) }, 100); // Trigger a scroll in case element is already viewable
}
} else { } else {
var triggerOn = getICAttribute($(elt), 'ic-trigger-on').split(" "); if(eventString.indexOf("sse:") == 0) {
var event = eventFor(triggerOn[0], $(elt)); //Server-sent event, find closest event source and register for it
$(getTriggeredElement(elt)).on(event, function(e) { var sourceElt = elt.closest(getICAttributeSelector('ic-sse-src'));
var onBeforeTrigger = closestAttrValue(elt, 'ic-on-beforeTrigger'); if(sourceElt.length > 0) {
if (onBeforeTrigger) { registerSSE(sourceElt, splitTriggerOn[0].substr(4))
if (globalEval(onBeforeTrigger, [["elt", elt], ["evt", e], ["elt", elt]]) == false) { }
log(elt, "ic-trigger cancelled by ic-on-beforeTrigger", "DEBUG"); } else {
$(getTriggeredElement(elt)).on(eventString, function(e) {
var onBeforeTrigger = closestAttrValue(elt, 'ic-on-beforeTrigger');
if (onBeforeTrigger) {
if (globalEval(onBeforeTrigger, [["elt", elt], ["evt", e], ["elt", elt]]) == false) {
log(elt, "ic-trigger cancelled by ic-on-beforeTrigger", "DEBUG");
return false;
}
}
if (eventModifier == 'changed') {
var currentVal = elt.val();
var previousVal = elt.data('ic-previous-val');
elt.data('ic-previous-val', currentVal);
if (currentVal != previousVal) {
fireICRequest(elt);
}
} else if (eventModifier == 'once') {
var alreadyTriggered = elt.data('ic-already-triggered');
elt.data('ic-already-triggered', true);
if (alreadyTriggered !== true) {
fireICRequest(elt);
}
} else {
fireICRequest(elt);
}
if (preventDefault(elt, e)) {
e.preventDefault();
return false; return false;
} }
return true;
});
if(eventString && (eventString.indexOf("timeout:") == 0)) {
var timeout = parseInterval(eventString.split(":")[1]);
setTimeout(function () {
$(getTriggeredElement(elt)).trigger(eventString);
}, timeout);
} }
if (triggerOn[1] == 'changed') {
var currentVal = elt.val();
var previousVal = elt.data('ic-previous-val');
elt.data('ic-previous-val', currentVal);
if (currentVal != previousVal) {
fireICRequest(elt);
}
} else if (triggerOn[1] == 'once') {
var alreadyTriggered = elt.data('ic-already-triggered');
elt.data('ic-already-triggered', true);
if (alreadyTriggered !== true) {
fireICRequest(elt);
}
} else {
fireICRequest(elt);
}
if (preventDefault(elt, e)) {
e.preventDefault();
return false;
}
return true;
});
if(event && (event.indexOf("timeout:") == 0)) {
setTimeout(function () {
$(getTriggeredElement(elt)).trigger(event);
}, parseInterval(event.split(":")[1]));
} }
} }
} }
@ -1178,6 +1247,7 @@ var Intercooler = Intercooler || (function() {
setIfAbsent(elt, 'ic-trigger-on', 'default'); setIfAbsent(elt, 'ic-trigger-on', 'default');
setIfAbsent(elt, 'ic-deps', 'ignore'); setIfAbsent(elt, 'ic-deps', 'ignore');
} }
if (macroIs(macro, 'ic-action')) { if (macroIs(macro, 'ic-action')) {
setIfAbsent(elt, 'ic-trigger-on', 'default'); setIfAbsent(elt, 'ic-trigger-on', 'default');
} }
@ -1209,6 +1279,51 @@ var Intercooler = Intercooler || (function() {
} }
} }
function isLocalLink(anchor) {
return location.hostname === anchor[0].hostname &&
anchor.attr('href') &&
!anchor.attr('href').startsWith("#")
}
function enhanceAnchor(anchor) {
if (closestAttrValue(anchor, 'ic-enhance') === "true") {
if (isLocalLink(anchor)) {
setIfAbsent(anchor, 'ic-src', anchor.attr('href'));
setIfAbsent(anchor, 'ic-trigger-on', 'default');
setIfAbsent(anchor, 'ic-deps', 'ignore');
setIfAbsent(anchor, 'ic-push-url', 'true');
}
}
}
function determineFormVerb(form) {
return form.find('input[name="_method"]').val() || form.attr('method') || form[0].method;
}
function enhanceForm(form) {
if (closestAttrValue(form, 'ic-enhance') === "true") {
setIfAbsent(form, 'ic-src', form.attr('action'));
setIfAbsent(form, 'ic-trigger-on', 'default');
setIfAbsent(form, 'ic-deps', 'ignore');
setIfAbsent(form, 'ic-verb', determineFormVerb(form));
}
}
function enhanceDomTree(elt) {
if(elt.is('a')) {
enhanceAnchor(elt);
}
elt.find('a').each(function(){
enhanceAnchor($(this));
});
if(elt.is('form')){
enhanceForm(elt);
}
elt.find('form').each(function(){
enhanceForm($(this));
});
}
function setIfAbsent(elt, attr, value) { function setIfAbsent(elt, attr, value) {
if (getICAttribute(elt, attr) == null) { if (getICAttribute(elt, attr) == null) {
setICAttribute(elt, attr, value); setICAttribute(elt, attr, value);
@ -1222,7 +1337,7 @@ var Intercooler = Intercooler || (function() {
function isScrolledIntoView(elem) { function isScrolledIntoView(elem) {
elem = $(elem); elem = $(elem);
if (elem.height() == 0 && elem.width() == 0) { if (elem.height() == 0 && elem.width() == 0) {
return false; return false;
} }
var docViewTop = $(window).scrollTop(); var docViewTop = $(window).scrollTop();
var docViewBottom = docViewTop + $(window).height(); var docViewBottom = docViewTop + $(window).height();
@ -1231,13 +1346,13 @@ var Intercooler = Intercooler || (function() {
var elemBottom = elemTop + elem.height(); var elemBottom = elemTop + elem.height();
return ((elemBottom >= docViewTop) && (elemTop <= docViewBottom) return ((elemBottom >= docViewTop) && (elemTop <= docViewBottom)
&& (elemBottom <= docViewBottom) && (elemTop >= docViewTop)); && (elemBottom <= docViewBottom) && (elemTop >= docViewTop));
} }
function maybeScrollToTarget(elt, target) { function maybeScrollToTarget(elt, target) {
if (closestAttrValue(elt, 'ic-scroll-to-target') != "false" && if (closestAttrValue(elt, 'ic-scroll-to-target') != "false" &&
(closestAttrValue(elt, 'ic-scroll-to-target') == 'true' || (closestAttrValue(elt, 'ic-scroll-to-target') == 'true' ||
closestAttrValue(target, 'ic-scroll-to-target') == 'true')) { closestAttrValue(target, 'ic-scroll-to-target') == 'true')) {
var offset = -50; // -50 px default offset padding var offset = -50; // -50 px default offset padding
if (closestAttrValue(elt, 'ic-scroll-offset')) { if (closestAttrValue(elt, 'ic-scroll-offset')) {
offset = parseInt(closestAttrValue(elt, 'ic-scroll-offset')); offset = parseInt(closestAttrValue(elt, 'ic-scroll-offset'));
@ -1352,6 +1467,19 @@ var Intercooler = Intercooler || (function() {
if (forHistory != true) { if (forHistory != true) {
maybeScrollToTarget(elt, target); maybeScrollToTarget(elt, target);
} }
var switchClass = elt.closest(getICAttributeSelector('ic-switch-class'));
var classToSwitch = switchClass.attr(fixICAttributeName('ic-switch-class'));
if(classToSwitch) {
switchClass.children().removeClass(classToSwitch);
switchClass.children().each(function(){
if($.contains($(this)[0], $(elt)[0]) || $(this)[0] == $(elt)[0]) {
$(this).addClass(classToSwitch);
$(this).addClass(classToSwitch);
}
})
}
} }
}; };
@ -1449,7 +1577,7 @@ var Intercooler = Intercooler || (function() {
} }
} }
function fireICRequest(elt, alternateHandler) { function fireICRequest(elt, alternateHandler) {
elt = $(elt); elt = $(elt);
var triggerOrigin = elt; var triggerOrigin = elt;
@ -1628,9 +1756,9 @@ var Intercooler = Intercooler || (function() {
/* Instance Methods */ /* Instance Methods */
function historyConfigHasChanged(historySupportData) { function historyConfigHasChanged(historySupportData) {
return historySupportData == null || return historySupportData == null ||
historySupportData.slotLimit != slotLimit || historySupportData.slotLimit != slotLimit ||
historySupportData.historyVersion != historyVersion || historySupportData.historyVersion != historyVersion ||
historySupportData.lruList == null historySupportData.lruList == null
} }
function clearHistory() { function clearHistory() {
@ -1687,18 +1815,19 @@ var Intercooler = Intercooler || (function() {
storage.setItem(restorationData.id, content); storage.setItem(restorationData.id, content);
} catch (e) { } catch (e) {
log(getTargetForHistory($('body')), "Unable to save intercooler history with entire history cleared, is something else eating " + log(getTargetForHistory($('body')), "Unable to save intercooler history with entire history cleared, is something else eating " +
"local storage? History Limit:" + slotLimit, "ERROR"); "local storage? History Limit:" + slotLimit, "ERROR");
} }
} }
} }
function makeHistoryEntry(html, yOffset, url) { function makeHistoryEntry(html, yOffset, url, title) {
var restorationData = { var restorationData = {
"url": url, "url": url,
"id": HISTORY_SLOT_PREFIX + url, "id": HISTORY_SLOT_PREFIX + url,
"content": html, "content": html,
"yOffset": yOffset, "yOffset": yOffset,
"timestamp": new Date().getTime() "timestamp": new Date().getTime(),
"title": title
}; };
updateLRUList(url); updateLRUList(url);
// save to the history slot // save to the history slot
@ -1724,18 +1853,18 @@ var Intercooler = Intercooler || (function() {
function updateHistory() { function updateHistory() {
if (_snapshot) { if (_snapshot) {
pushUrl(_snapshot.newUrl, currentUrl(), _snapshot.oldHtml, _snapshot.yOffset); pushUrl(_snapshot.newUrl, currentUrl(), _snapshot.oldHtml, _snapshot.yOffset, _snapshot.oldTitle);
_snapshot = null; _snapshot = null;
} }
} }
function pushUrl(newUrl, originalUrl, originalHtml, yOffset) { function pushUrl(newUrl, originalUrl, originalHtml, yOffset, originalTitle) {
var historyEntry = makeHistoryEntry(originalHtml, yOffset, originalUrl); var historyEntry = makeHistoryEntry(originalHtml, yOffset, originalUrl, originalTitle);
history.replaceState({"ic-id": historyEntry.id}, "", ""); history.replaceState({"ic-id": historyEntry.id}, "", "");
var t = getTargetForHistory($('body')); var t = getTargetForHistory($('body'));
var restorationData = makeHistoryEntry(t.html(), window.pageYOffset, newUrl); var restorationData = makeHistoryEntry(t.html(), window.pageYOffset, newUrl, document.title);
history.pushState({'ic-id': restorationData.id}, "", newUrl); history.pushState({'ic-id': restorationData.id}, "", newUrl);
triggerEvent(t, "pushUrl.ic", [t, restorationData]); triggerEvent(t, "pushUrl.ic", [t, restorationData]);
@ -1748,7 +1877,12 @@ var Intercooler = Intercooler || (function() {
if (historyData) { if (historyData) {
processICResponse(historyData["content"], getTargetForHistory($('body')), true); processICResponse(historyData["content"], getTargetForHistory($('body')), true);
if (historyData["yOffset"]) { if (historyData["yOffset"]) {
window.scrollTo(0, historyData["yOffset"]) setTimeout(function () {
window.scrollTo(0, historyData["yOffset"]);
}, 100);
}
if (historyData["title"]) {
document.title = historyData["title"];
} }
return true; return true;
} else { } else {
@ -1771,13 +1905,14 @@ var Intercooler = Intercooler || (function() {
} }
} }
function snapshotForHistory(newUrl) { function snapshotForHistory(newUrl, oldTitle) {
var t = getTargetForHistory($('body')); var t = getTargetForHistory($('body'));
triggerEvent(t, "beforeHistorySnapshot.ic", [t]); triggerEvent(t, "beforeHistorySnapshot.ic", [t]);
_snapshot = { _snapshot = {
newUrl: newUrl, newUrl: newUrl,
oldHtml: t.html(), oldHtml: t.html(),
yOffset: window.pageYOffset yOffset: window.pageYOffset,
oldTitle: oldTitle
}; };
} }
@ -1897,12 +2032,11 @@ var Intercooler = Intercooler || (function() {
if($.zepto) { if($.zepto) {
$('body').data('zeptoDataTest', {}); $('body').data('zeptoDataTest', {});
if(typeof($('body').data('zeptoDataTest')) == "string") { if(typeof($('body').data('zeptoDataTest')) == "string") {
console.log("!!!! Please include the data module with Zepto! Intercooler requires full data support to function !!!!") log(null,
"!!!! Please include the data module with Zepto! Intercooler requires full data support to function !!!!",
"ERROR")
} }
} }
if (location.search && location.search.indexOf("ic-launch-debugger=true") >= 0) {
Intercooler.debug();
}
} }
$(function() { $(function() {
@ -1922,27 +2056,22 @@ var Intercooler = Intercooler || (function() {
isDependent: isDependent, isDependent: isDependent,
getTarget: getTarget, getTarget: getTarget,
processHeaders: processHeaders, processHeaders: processHeaders,
startPolling: startPolling,
cancelPolling: cancelPolling,
setIsDependentFunction: function(func) { setIsDependentFunction: function(func) {
_isDependentFunction = func; _isDependentFunction = func;
}, },
ready: function(readyHandler) { ready: function(readyHandler) {
_readyHandlers.push(readyHandler); _readyHandlers.push(readyHandler);
}, },
debug: function() {
var debuggerUrl = closestAttrValue('body', 'ic-debugger-url') ||
"https://intercoolerreleases-leaddynocom.netdna-ssl.com/intercooler-debugger.js";
$.getScript(debuggerUrl)
.fail(function(jqxhr, settings, exception) {
log($('body'), formatError(exception), "ERROR");
});
},
_internal: { _internal: {
init: init, init: init,
replaceOrAddMethod: replaceOrAddMethod, replaceOrAddMethod: replaceOrAddMethod,
initEventSource: function(url) { initEventSource: function(url, withCredentials) {
return new EventSource(url); return new EventSource(url, {withCredentials: withCredentials});
}, },
globalEval: globalEval globalEval: globalEval,
getLocalURL: getLocalURL
} }
}; };
})(); })();