mirror of
https://github.com/bigskysoftware/htmx.git
synced 2025-10-02 15:25:26 +00:00
142 lines
6.3 KiB
JavaScript
142 lines
6.3 KiB
JavaScript
describe("path-deps extension", function() {
|
|
beforeEach(function () {
|
|
this.server = makeServer();
|
|
clearWorkArea();
|
|
});
|
|
afterEach(function () {
|
|
this.server.restore();
|
|
clearWorkArea();
|
|
});
|
|
|
|
it('path-deps basic case works', function () {
|
|
this.server.respondWith("POST", "/test", "Clicked!");
|
|
this.server.respondWith("GET", "/test2", "Deps fired!");
|
|
var btn = make('<button hx-post="/test" hx-ext="path-deps">Click Me!</button>')
|
|
var div = make('<div hx-get="/test2" hx-trigger="path-deps" path-deps="/test">FOO</div>')
|
|
btn.click();
|
|
this.server.respond();
|
|
btn.innerHTML.should.equal("Clicked!");
|
|
div.innerHTML.should.equal("FOO");
|
|
this.server.respond();
|
|
div.innerHTML.should.equal("Deps fired!");
|
|
});
|
|
|
|
it('path-deps works with trailing slash', function () {
|
|
this.server.respondWith("POST", "/test", "Clicked!");
|
|
this.server.respondWith("GET", "/test2", "Deps fired!");
|
|
var btn = make('<button hx-post="/test" hx-ext="path-deps">Click Me!</button>')
|
|
var div = make('<div hx-get="/test2" hx-trigger="path-deps" path-deps="/test/">FOO</div>')
|
|
btn.click();
|
|
this.server.respond();
|
|
btn.innerHTML.should.equal("Clicked!");
|
|
div.innerHTML.should.equal("FOO");
|
|
this.server.respond();
|
|
div.innerHTML.should.equal("Deps fired!");
|
|
});
|
|
|
|
it('path-deps GET does not trigger', function () {
|
|
this.server.respondWith("GET", "/test", "Clicked!");
|
|
this.server.respondWith("GET", "/test2", "Deps fired!");
|
|
var btn = make('<button hx-get="/test" hx-ext="path-deps">Click Me!</button>')
|
|
var div = make('<div hx-get="/test2" hx-trigger="path-deps" path-deps="/test">FOO</div>')
|
|
btn.click();
|
|
this.server.respond();
|
|
btn.innerHTML.should.equal("Clicked!");
|
|
div.innerHTML.should.equal("FOO");
|
|
this.server.respond();
|
|
div.innerHTML.should.equal("FOO");
|
|
});
|
|
|
|
it('path-deps dont trigger on path mismatch', function () {
|
|
this.server.respondWith("POST", "/test", "Clicked!");
|
|
this.server.respondWith("GET", "/test2", "Deps fired!");
|
|
var btn = make('<button hx-post="/test" hx-ext="path-deps">Click Me!</button>')
|
|
var div = make('<div hx-get="/test2" hx-trigger="path-deps" path-deps="/test2">FOO</div>')
|
|
btn.click();
|
|
this.server.respond();
|
|
btn.innerHTML.should.equal("Clicked!");
|
|
div.innerHTML.should.equal("FOO");
|
|
this.server.respond();
|
|
div.innerHTML.should.equal("FOO");
|
|
});
|
|
|
|
it('path-deps dont trigger on path longer than request', function () {
|
|
this.server.respondWith("POST", "/test", "Clicked!");
|
|
this.server.respondWith("GET", "/test2", "Deps fired!");
|
|
var btn = make('<button hx-post="/test" hx-ext="path-deps">Click Me!</button>')
|
|
var div = make('<div hx-get="/test2" hx-trigger="path-deps" path-deps="/test/child">FOO</div>')
|
|
btn.click();
|
|
this.server.respond();
|
|
btn.innerHTML.should.equal("Clicked!");
|
|
div.innerHTML.should.equal("FOO");
|
|
this.server.respond();
|
|
div.innerHTML.should.equal("FOO");
|
|
});
|
|
|
|
it('path-deps trigger on path shorter than request', function () {
|
|
this.server.respondWith("POST", "/test/child", "Clicked!");
|
|
this.server.respondWith("GET", "/test2", "Deps fired!");
|
|
var btn = make('<button hx-post="/test/child" hx-ext="path-deps">Click Me!</button>')
|
|
var div = make('<div hx-get="/test2" hx-trigger="path-deps" path-deps="/test">FOO</div>')
|
|
btn.click();
|
|
this.server.respond();
|
|
btn.innerHTML.should.equal("Clicked!");
|
|
div.innerHTML.should.equal("FOO");
|
|
this.server.respond();
|
|
div.innerHTML.should.equal("Deps fired!");
|
|
});
|
|
|
|
it('path-deps trigger on *-at-start path', function () {
|
|
this.server.respondWith("POST", "/test/child/test", "Clicked!");
|
|
this.server.respondWith("GET", "/test2", "Deps fired!");
|
|
var btn = make('<button hx-post="/test/child/test" hx-ext="path-deps">Click Me!</button>')
|
|
var div = make('<div hx-get="/test2" hx-trigger="path-deps" path-deps="/*/child/test">FOO</div>')
|
|
btn.click();
|
|
this.server.respond();
|
|
btn.innerHTML.should.equal("Clicked!");
|
|
div.innerHTML.should.equal("FOO");
|
|
this.server.respond();
|
|
div.innerHTML.should.equal("Deps fired!");
|
|
});
|
|
|
|
it('path-deps trigger on *-in-middle path', function () {
|
|
this.server.respondWith("POST", "/test/child/test", "Clicked!");
|
|
this.server.respondWith("GET", "/test2", "Deps fired!");
|
|
var btn = make('<button hx-post="/test/child/test" hx-ext="path-deps">Click Me!</button>')
|
|
var div = make('<div hx-get="/test2" hx-trigger="path-deps" path-deps="/test/*/test">FOO</div>')
|
|
btn.click();
|
|
this.server.respond();
|
|
btn.innerHTML.should.equal("Clicked!");
|
|
div.innerHTML.should.equal("FOO");
|
|
this.server.respond();
|
|
div.innerHTML.should.equal("Deps fired!");
|
|
});
|
|
|
|
it('path-deps trigger on *-at-end path', function () {
|
|
this.server.respondWith("POST", "/test/child/test", "Clicked!");
|
|
this.server.respondWith("GET", "/test2", "Deps fired!");
|
|
var btn = make('<button hx-post="/test/child/test" hx-ext="path-deps">Click Me!</button>')
|
|
var div = make('<div hx-get="/test2" hx-trigger="path-deps" path-deps="/test/child/*">FOO</div>')
|
|
btn.click();
|
|
this.server.respond();
|
|
btn.innerHTML.should.equal("Clicked!");
|
|
div.innerHTML.should.equal("FOO");
|
|
this.server.respond();
|
|
div.innerHTML.should.equal("Deps fired!");
|
|
});
|
|
|
|
it('path-deps trigger all *s path', function () {
|
|
this.server.respondWith("POST", "/test/child/test", "Clicked!");
|
|
this.server.respondWith("GET", "/test2", "Deps fired!");
|
|
var btn = make('<button hx-post="/test/child/test" hx-ext="path-deps">Click Me!</button>')
|
|
var div = make('<div hx-get="/test2" hx-trigger="path-deps" path-deps="/*/*/*">FOO</div>')
|
|
btn.click();
|
|
this.server.respond();
|
|
btn.innerHTML.should.equal("Clicked!");
|
|
div.innerHTML.should.equal("FOO");
|
|
this.server.respond();
|
|
div.innerHTML.should.equal("Deps fired!");
|
|
});
|
|
|
|
|
|
}); |