123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246 |
- if ($.support.pjax) {
- module("$.fn.pjax", {
- setup: function() {
- var self = this
- stop()
- window.iframeLoad = function(frame) {
- self.frame = frame
- window.iframeLoad = $.noop
- start()
- }
- $("#qunit-fixture").append("<iframe src='home.html'>")
- },
- teardown: function() {
- delete window.iframeLoad
- }
- })
- asyncTest("pushes new url", function() {
- var frame = this.frame
- frame.$("#main").pjax("a", "#main").on("pjax:end", function() {
- equal(frame.location.pathname, "/dinosaurs.html")
- start()
- })
- frame.$("a[href='/dinosaurs.html']").click()
- })
- asyncTest("replaces container html from response data", function() {
- var frame = this.frame
- frame.$("#main").pjax("a", "#main").on("pjax:end", function() {
- equal(frame.$("iframe").attr('title'), "YouTube video player")
- start()
- })
- frame.$("a[href='/dinosaurs.html']").click()
- })
- asyncTest("sets title to response title tag", function() {
- var frame = this.frame
- frame.$("#main").pjax("a", "#main").on("pjax:end", function() {
- equal(frame.document.title, "dinosaurs")
- start()
- })
- frame.$("a[href='/dinosaurs.html']").trigger('click')
- })
- asyncTest("uses second argument as options", function() {
- var frame = this.frame
- frame.$("#main").pjax("a", {container: "#main", push: true}).on("pjax:end", function() {
- equal(frame.location.pathname, "/dinosaurs.html")
- start()
- })
- frame.$("a[href='/dinosaurs.html']").click()
- })
- asyncTest("uses second argument as container and third as options", function() {
- var frame = this.frame
- frame.$("body").pjax("a", "#main", {push: true}).on("pjax:end", function() {
- equal(frame.location.pathname, "/dinosaurs.html")
- start()
- })
- frame.$("a[href='/dinosaurs.html']").click()
- })
- asyncTest("defaults to data-pjax container", function() {
- var frame = this.frame
- frame.$("a").attr('data-pjax', "#main")
- frame.$("body").pjax("a")
- frame.$("#main").on("pjax:end", function() {
- equal(frame.location.pathname, "/dinosaurs.html")
- start()
- })
- frame.$("a[href='/dinosaurs.html']").click()
- })
- asyncTest("sets relatedTarget to clicked element", function() {
- var frame = this.frame
- frame.$("#main").pjax("a", "#main")
- var link = frame.$("a[href='/dinosaurs.html']")[0]
- frame.$("#main").on("pjax:end", function(event, xhr, options) {
- equal(link, event.relatedTarget)
- start()
- })
- frame.$(link).click()
- })
- asyncTest("doesn't ignore left click", function() {
- var frame = this.frame
- frame.$("#main").pjax("a", "#main")
- var event = frame.$.Event('click')
- event.which = 0
- frame.$("a[href='/dinosaurs.html']").trigger(event)
- ok(event.isDefaultPrevented())
- start()
- })
- asyncTest("ignores middle clicks", function() {
- var frame = this.frame
- frame.$("#main").pjax("a", "#main")
- var event = frame.$.Event('click')
- event.which = 3
- frame.$("a[href='/dinosaurs.html']").trigger(event)
- ok(!event.isDefaultPrevented())
- start()
- })
- asyncTest("ignores command clicks", function() {
- var frame = this.frame
- frame.$("#main").pjax("a")
- var event = frame.$.Event('click')
- event.metaKey = true
- frame.$("a[href='/dinosaurs.html']").trigger(event)
- ok(!event.isDefaultPrevented())
- start()
- })
- asyncTest("ignores ctrl clicks", function() {
- var frame = this.frame
- frame.$("#main").pjax("a")
- var event = frame.$.Event('click')
- event.ctrlKey = true
- frame.$("a[href='/dinosaurs.html']").trigger(event)
- ok(!event.isDefaultPrevented())
- start()
- })
- asyncTest("ignores cross origin links", function() {
- var frame = this.frame
- frame.$("#main").pjax("a")
- var event = frame.$.Event('click')
- frame.$("a[href='https://www.google.com/']").trigger(event)
- notEqual(event.result, false)
- start()
- })
- asyncTest("ignores same page anchors", function() {
- var event, frame = this.frame
- frame.$("#main").pjax("a")
- event = frame.$.Event('click')
- frame.$("a[href='#main']").trigger(event)
- equal(event.isDefaultPrevented(), false)
- event = frame.$.Event('click')
- frame.$("a[href='#']").trigger(event)
- equal(event.isDefaultPrevented(), false)
- start()
- })
- asyncTest("ignores same page anchors from URL that has hash", function() {
- var event, frame = this.frame
- frame.window.location = "#foo"
- frame.$("#main").pjax("a")
- event = frame.$.Event('click')
- frame.$("a[href='#main']").trigger(event)
- equal(event.isDefaultPrevented(), false)
- event = frame.$.Event('click')
- frame.$("a[href='#']").trigger(event)
- equal(event.isDefaultPrevented(), false)
- start()
- })
- asyncTest("ignores event with prevented default", function() {
- var frame = this.frame
- var eventIgnored = true
- frame.$("#main").pjax("a").on("pjax:click", function() {
- eventIgnored = false
- })
- frame.$("a[href='/dinosaurs.html']").on("click", function(event) {
- event.preventDefault()
- setTimeout(function() {
- ok(eventIgnored, "Event with prevented default ignored")
- start()
- }, 10)
- })
- frame.$("a[href='/dinosaurs.html']").click()
- })
- asyncTest("triggers pjax:click event from link", function() {
- var frame = this.frame
- frame.$("#main").pjax("a", "#main").on("pjax:click", function(event, options) {
- ok(event)
- equal(options.container, "#main")
- ok(options.url.match("/dinosaurs.html"))
- start()
- })
- frame.$("a[href='/dinosaurs.html']").click()
- })
- asyncTest("triggers pjax:clicked event from link", function() {
- var frame = this.frame
- frame.$("#main").pjax("a", "#main").on("pjax:clicked", function(event, options) {
- ok(event)
- equal(options.container, "#main")
- ok(options.url.match("/dinosaurs.html"))
- start()
- })
- frame.$("a[href='/dinosaurs.html']").click()
- })
- }
|