Files
pjax/lib/proto/attach-link.js

83 lines
2.1 KiB
JavaScript
Raw Normal View History

2014-05-22 06:20:38 +02:00
var on = require("../events/on")
var clone = require("../util/clone")
2014-05-22 06:20:38 +02:00
var attrState = "data-pjax-state"
2014-05-22 06:20:38 +02:00
var linkAction = function(el, event) {
if (isDefaultPrevented(event)) {
return
}
// Since loadUrl modifies options and we may add our own modifications below,
// clone it so the changes don't persist
var options = clone(this.options)
var attrValue = checkIfShouldAbort(el, event)
if (attrValue) {
el.setAttribute(attrState, attrValue)
return
}
event.preventDefault()
// dont do "nothing" if user try to reload the page by clicking the same link twice
if (
this.options.currentUrlFullReload &&
el.href === window.location.href.split("#")[0]
) {
el.setAttribute(attrState, "reload")
this.reload()
return
}
el.setAttribute(attrState, "load")
options.triggerElement = el
this.loadUrl(el.href, options)
}
function checkIfShouldAbort(el, event) {
2014-05-22 06:20:38 +02:00
// Dont break browser special behavior on links (like page in new window)
if (event.which > 1 || event.metaKey || event.ctrlKey || event.shiftKey || event.altKey) {
return "modifier"
2014-05-22 06:20:38 +02:00
}
// we do test on href now to prevent unexpected behavior if for some reason
// user have href that can be dynamically updated
// Ignore external links.
if (el.protocol !== window.location.protocol || el.host !== window.location.host) {
return "external"
2014-05-22 06:20:38 +02:00
}
// Ignore anchors on the same page (keep native behavior)
if (el.hash && el.href.replace(el.hash, "") === window.location.href.replace(location.hash, "")) {
return "anchor"
2014-05-22 06:20:38 +02:00
}
// Ignore empty anchor "foo.html#"
if (el.href === window.location.href.split("#")[0] + "#") {
return "anchor-empty"
2014-05-22 06:20:38 +02:00
}
}
var isDefaultPrevented = function(event) {
return event.defaultPrevented || event.returnValue === false
}
2014-05-22 06:20:38 +02:00
module.exports = function(el) {
2014-10-14 11:42:36 +02:00
var that = this
2014-05-22 06:20:38 +02:00
el.setAttribute(attrState, "")
on(el, "click", function(event) {
2014-10-14 11:42:36 +02:00
linkAction.call(that, el, event)
2014-05-22 06:20:38 +02:00
})
on(el, "keyup", function(event) {
if (event.keyCode === 13) {
2014-10-14 11:42:36 +02:00
linkAction.call(that, el, event)
2014-05-22 06:20:38 +02:00
}
}.bind(this))
}