mirror of
https://github.com/bigskysoftware/htmx.git
synced 2025-09-28 13:31:06 +00:00
261 lines
8.9 KiB
JavaScript
261 lines
8.9 KiB
JavaScript
describe("Core htmx Events", function() {
|
|
beforeEach(function () {
|
|
this.server = makeServer();
|
|
clearWorkArea();
|
|
});
|
|
afterEach(function () {
|
|
this.server.restore();
|
|
clearWorkArea();
|
|
});
|
|
|
|
it("htmx:load fires properly", function () {
|
|
var called = false;
|
|
var handler = htmx.on("htmx:load", function (evt) {
|
|
called = true;
|
|
});
|
|
try {
|
|
this.server.respondWith("GET", "/test", "");
|
|
this.server.respondWith("GET", "/test", "<div></div>");
|
|
var div = make("<div hx-get='/test'></div>");
|
|
div.click();
|
|
this.server.respond();
|
|
should.equal(called, true);
|
|
} finally {
|
|
htmx.off("htmx:load", handler);
|
|
}
|
|
});
|
|
|
|
it("htmx:configRequest allows attribute addition", function () {
|
|
var handler = htmx.on("htmx:configRequest", function (evt) {
|
|
evt.detail.parameters['param'] = "true";
|
|
});
|
|
try {
|
|
var param = null;
|
|
this.server.respondWith("POST", "/test", function (xhr) {
|
|
param = getParameters(xhr)['param'];
|
|
xhr.respond(200, {}, "");
|
|
});
|
|
var div = make("<div hx-post='/test'></div>");
|
|
div.click();
|
|
this.server.respond();
|
|
param.should.equal("true");
|
|
} finally {
|
|
htmx.off("htmx:configRequest", handler);
|
|
}
|
|
});
|
|
|
|
it("htmx:configRequest is also dispatched in kebab-case", function () {
|
|
var handler = htmx.on("htmx:config-request", function (evt) {
|
|
evt.detail.parameters['param'] = "true";
|
|
});
|
|
try {
|
|
var param = null;
|
|
this.server.respondWith("POST", "/test", function (xhr) {
|
|
param = getParameters(xhr)['param'];
|
|
xhr.respond(200, {}, "");
|
|
});
|
|
var div = make("<div hx-post='/test'></div>");
|
|
div.click();
|
|
this.server.respond();
|
|
param.should.equal("true");
|
|
} finally {
|
|
htmx.off("htmx:config-request", handler);
|
|
}
|
|
});
|
|
|
|
it("events are only dispatched once if kebab and camel case match", function () {
|
|
var invoked = 0;
|
|
var handler = htmx.on("custom", function () {
|
|
invoked = invoked + 1
|
|
});
|
|
try {
|
|
var div = make("<div hx-post='/test'></div>");
|
|
htmx.trigger(div, "custom");
|
|
invoked.should.equal(1);
|
|
} finally {
|
|
htmx.off("custom", handler);
|
|
}
|
|
});
|
|
|
|
it("htmx:configRequest allows attribute removal", function () {
|
|
var param = "foo";
|
|
var handler = htmx.on("htmx:configRequest", function (evt) {
|
|
delete evt.detail.parameters['param'];
|
|
});
|
|
try {
|
|
this.server.respondWith("POST", "/test", function (xhr) {
|
|
param = getParameters(xhr)['param'];
|
|
xhr.respond(200, {}, "");
|
|
});
|
|
var div = make("<form hx-trigger='click' hx-post='/test'><input name='param' value='foo'></form>");
|
|
div.click();
|
|
this.server.respond();
|
|
should.equal(param, undefined);
|
|
} finally {
|
|
htmx.off("htmx:configRequest", handler);
|
|
}
|
|
});
|
|
|
|
it("htmx:configRequest allows header tweaking", function () {
|
|
var header = "foo";
|
|
var handler = htmx.on("htmx:configRequest", function (evt) {
|
|
evt.detail.headers['X-My-Header'] = "bar";
|
|
});
|
|
try {
|
|
this.server.respondWith("POST", "/test", function (xhr) {
|
|
header = xhr.requestHeaders['X-My-Header'];
|
|
xhr.respond(200, {}, "");
|
|
});
|
|
var div = make("<form hx-trigger='click' hx-post='/test'><input name='param' value='foo'></form>");
|
|
div.click();
|
|
this.server.respond();
|
|
should.equal(header, "bar");
|
|
} finally {
|
|
htmx.off("htmx:configRequest", handler);
|
|
}
|
|
});
|
|
|
|
it("htmx:afterSwap is called when replacing outerHTML", function () {
|
|
var called = false;
|
|
var handler = htmx.on("htmx:afterSwap", function (evt) {
|
|
called = true;
|
|
});
|
|
try {
|
|
this.server.respondWith("POST", "/test", function (xhr) {
|
|
xhr.respond(200, {}, "<button>Bar</button>");
|
|
});
|
|
var div = make("<button hx-post='/test' hx-swap='outerHTML'>Foo</button>");
|
|
div.click();
|
|
this.server.respond();
|
|
should.equal(called, true);
|
|
} finally {
|
|
htmx.off("htmx:afterSwap", handler);
|
|
}
|
|
});
|
|
|
|
it("htmx:afterSettle is called when replacing outerHTML", function () {
|
|
var called = false;
|
|
var handler = htmx.on("htmx:afterSettle", function (evt) {
|
|
called = true;
|
|
});
|
|
try {
|
|
this.server.respondWith("POST", "/test", function (xhr) {
|
|
xhr.respond(200, {}, "<button>Bar</button>");
|
|
});
|
|
var div = make("<button hx-post='/test' hx-swap='outerHTML'>Foo</button>");
|
|
div.click();
|
|
this.server.respond();
|
|
should.equal(called, true);
|
|
} finally {
|
|
htmx.off("htmx:afterSettle", handler);
|
|
}
|
|
});
|
|
|
|
it("htmx:afterRequest is called after a successful request", function () {
|
|
var called = false;
|
|
var handler = htmx.on("htmx:afterRequest", function (evt) {
|
|
called = true;
|
|
});
|
|
try {
|
|
this.server.respondWith("POST", "/test", function (xhr) {
|
|
xhr.respond(200, {}, "");
|
|
});
|
|
var div = make("<button hx-post='/test'>Foo</button>");
|
|
div.click();
|
|
this.server.respond();
|
|
should.equal(called, true);
|
|
} finally {
|
|
htmx.off("htmx:afterRequest", handler);
|
|
}
|
|
});
|
|
|
|
it("htmx:afterOnLoad is called after a successful request", function () {
|
|
var called = false;
|
|
var handler = htmx.on("htmx:afterOnLoad", function (evt) {
|
|
called = true;
|
|
});
|
|
try {
|
|
this.server.respondWith("POST", "/test", function (xhr) {
|
|
xhr.respond(200, {}, "");
|
|
});
|
|
var div = make("<button hx-post='/test'>Foo</button>");
|
|
div.click();
|
|
this.server.respond();
|
|
should.equal(called, true);
|
|
} finally {
|
|
htmx.off("htmx:afterOnLoad", handler);
|
|
}
|
|
});
|
|
|
|
it("htmx:afterRequest is called after a failed request", function () {
|
|
var called = false;
|
|
var handler = htmx.on("htmx:afterRequest", function (evt) {
|
|
called = true;
|
|
});
|
|
try {
|
|
this.server.respondWith("POST", "/test", function (xhr) {
|
|
xhr.respond(200, {}, "");
|
|
});
|
|
var div = make("<button hx-post='/test'>Foo</button>");
|
|
div.click();
|
|
this.server.respond();
|
|
should.equal(called, true);
|
|
} finally {
|
|
htmx.off("htmx:afterRequest", handler);
|
|
}
|
|
});
|
|
|
|
it("htmx:sendError is called after a failed request", function (done) {
|
|
var called = false;
|
|
var handler = htmx.on("htmx:sendError", function (evt) {
|
|
called = true;
|
|
});
|
|
this.server.restore(); // turn off server mock so connection doesn't work
|
|
var div = make("<button hx-post='file://foo'>Foo</button>");
|
|
div.click();
|
|
setTimeout(function () {
|
|
htmx.off("htmx:sendError", handler);
|
|
should.equal(called, true);
|
|
done();
|
|
}, 30);
|
|
});
|
|
|
|
it("htmx:afterRequest is called when replacing outerHTML", function () {
|
|
var called = false;
|
|
var handler = htmx.on("htmx:afterRequest", function (evt) {
|
|
called = true;
|
|
});
|
|
try {
|
|
this.server.respondWith("POST", "/test", function (xhr) {
|
|
xhr.respond(200, {}, "<button>Bar</button>");
|
|
});
|
|
var div = make("<button hx-post='/test' hx-swap='outerHTML'>Foo</button>");
|
|
div.click();
|
|
this.server.respond();
|
|
should.equal(called, true);
|
|
} finally {
|
|
htmx.off("htmx:afterRequest", handler);
|
|
}
|
|
});
|
|
|
|
it("htmx:afterOnLoad is called when replacing outerHTML", function () {
|
|
var called = false;
|
|
var handler = htmx.on("htmx:afterOnLoad", function (evt) {
|
|
called = true;
|
|
});
|
|
try {
|
|
this.server.respondWith("POST", "/test", function (xhr) {
|
|
xhr.respond(200, {}, "<button>Bar</button>");
|
|
});
|
|
var div = make("<button hx-post='/test' hx-swap='outerHTML'>Foo</button>");
|
|
div.click();
|
|
this.server.respond();
|
|
should.equal(called, true);
|
|
} finally {
|
|
htmx.off("htmx:afterOnLoad", handler);
|
|
}
|
|
});
|
|
|
|
});
|
|
|