mirror of
https://github.com/bigskysoftware/htmx.git
synced 2025-09-27 04:50:43 +00:00
123 lines
5.4 KiB
JavaScript
123 lines
5.4 KiB
JavaScript
describe("hx-swap-oob attribute", function () {
|
|
beforeEach(function () {
|
|
this.server = makeServer();
|
|
clearWorkArea();
|
|
});
|
|
afterEach(function () {
|
|
this.server.restore();
|
|
clearWorkArea();
|
|
});
|
|
|
|
it('handles basic response properly', function () {
|
|
this.server.respondWith("GET", "/test", "Clicked<div id='d1' hx-swap-oob='true'>Swapped</div>");
|
|
var div = make('<div hx-get="/test">click me</div>');
|
|
make('<div id="d1"></div>');
|
|
div.click();
|
|
this.server.respond();
|
|
div.innerHTML.should.equal("Clicked");
|
|
byId("d1").innerHTML.should.equal("Swapped");
|
|
})
|
|
|
|
it('handles more than one oob swap properly', function () {
|
|
this.server.respondWith("GET", "/test", "Clicked<div id='d1' hx-swap-oob='true'>Swapped1</div><div id='d2' hx-swap-oob='true'>Swapped2</div>");
|
|
var div = make('<div hx-get="/test">click me</div>');
|
|
make('<div id="d1"></div>');
|
|
make('<div id="d2"></div>');
|
|
div.click();
|
|
this.server.respond();
|
|
div.innerHTML.should.equal("Clicked");
|
|
byId("d1").innerHTML.should.equal("Swapped1");
|
|
byId("d2").innerHTML.should.equal("Swapped2");
|
|
})
|
|
|
|
it('handles no id match properly', function () {
|
|
this.server.respondWith("GET", "/test", "Clicked<div id='d1' hx-swap-oob='true'>Swapped</div>");
|
|
var div = make('<div hx-get="/test">click me</div>');
|
|
div.click();
|
|
this.server.respond();
|
|
div.innerText.should.equal("Clicked");
|
|
})
|
|
|
|
it('handles basic response properly w/ data-* prefix', function () {
|
|
this.server.respondWith("GET", "/test", "Clicked<div id='d1' data-hx-swap-oob='true'>Swapped</div>");
|
|
var div = make('<div data-hx-get="/test">click me</div>');
|
|
make('<div id="d1"></div>');
|
|
div.click();
|
|
this.server.respond();
|
|
div.innerHTML.should.equal("Clicked");
|
|
byId("d1").innerHTML.should.equal("Swapped");
|
|
})
|
|
|
|
it('handles outerHTML response properly', function () {
|
|
this.server.respondWith("GET", "/test", "Clicked<div id='d1' foo='bar' hx-swap-oob='outerHTML'>Swapped</div>");
|
|
var div = make('<div hx-get="/test">click me</div>');
|
|
make('<div id="d1"></div>');
|
|
div.click();
|
|
this.server.respond();
|
|
byId("d1").getAttribute("foo").should.equal("bar");
|
|
div.innerHTML.should.equal("Clicked");
|
|
byId("d1").innerHTML.should.equal("Swapped");
|
|
})
|
|
|
|
it('handles innerHTML response properly', function () {
|
|
this.server.respondWith("GET", "/test", "Clicked<div id='d1' foo='bar' hx-swap-oob='innerHTML'>Swapped</div>");
|
|
var div = make('<div hx-get="/test">click me</div>');
|
|
make('<div id="d1"></div>');
|
|
div.click();
|
|
this.server.respond();
|
|
should.equal(byId("d1").getAttribute("foo"), null);
|
|
div.innerHTML.should.equal("Clicked");
|
|
byId("d1").innerHTML.should.equal("Swapped");
|
|
})
|
|
|
|
it('oob swaps can be nested in content', function () {
|
|
this.server.respondWith("GET", "/test", "<div>Clicked<div id='d1' foo='bar' hx-swap-oob='innerHTML'>Swapped</div></div>");
|
|
var div = make('<div hx-get="/test">click me</div>');
|
|
make('<div id="d1"></div>');
|
|
div.click();
|
|
this.server.respond();
|
|
should.equal(byId("d1").getAttribute("foo"), null);
|
|
div.innerHTML.should.equal("<div>Clicked</div>");
|
|
byId("d1").innerHTML.should.equal("Swapped");
|
|
})
|
|
|
|
it('oob swaps can use selectors to match up', function () {
|
|
this.server.respondWith("GET", "/test", "<div>Clicked<div hx-swap-oob='innerHTML:[foo]'>Swapped</div></div>");
|
|
var div = make('<div hx-get="/test">click me</div>');
|
|
make('<div id="d1" foo="bar"></div>');
|
|
div.click();
|
|
this.server.respond();
|
|
should.equal(byId("d1").getAttribute("foo"), "bar");
|
|
div.innerHTML.should.equal("<div>Clicked</div>");
|
|
byId("d1").innerHTML.should.equal("Swapped");
|
|
})
|
|
|
|
it('swaps into all targets that match the selector (innerHTML)', function () {
|
|
this.server.respondWith("GET", "/test", "<div>Clicked</div><div class='target' hx-swap-oob='innerHTML:.target'>Swapped</div>");
|
|
var div = make('<div hx-get="/test">click me</div>');
|
|
make('<div id="d1">No swap</div>');
|
|
make('<div id="d2" class="target">Not swapped</div>');
|
|
make('<div id="d3" class="target">Not swapped</div>');
|
|
div.click();
|
|
this.server.respond();
|
|
byId("d1").innerHTML.should.equal("No swap");
|
|
byId("d2").innerHTML.should.equal("Swapped");
|
|
byId("d3").innerHTML.should.equal("Swapped");
|
|
})
|
|
|
|
it('swaps into all targets that match the selector (outerHTML)', function () {
|
|
var oobSwapContent = '<div class="new-target" hx-swap-oob="outerHTML:.target">Swapped</div>';
|
|
this.server.respondWith("GET", "/test", "<div>Clicked</div>" + oobSwapContent);
|
|
var div = make('<div hx-get="/test">click me</div>');
|
|
make('<div id="d1"><div>No swap</div></div>');
|
|
make('<div id="d2"><div class="target">Not swapped</div></div>');
|
|
make('<div id="d3"><div class="target">Not swapped</div></div>');
|
|
div.click();
|
|
this.server.respond();
|
|
byId("d1").innerHTML.should.equal("<div>No swap</div>");
|
|
byId("d2").innerHTML.should.equal(oobSwapContent);
|
|
byId("d3").innerHTML.should.equal(oobSwapContent);
|
|
})
|
|
});
|
|
|