describe("hyperscript integration", function() { beforeEach(function () { this.server = makeServer(); clearWorkArea(); }); afterEach(function () { this.server.restore(); clearWorkArea(); }); it('can trigger with a custom event', function () { this.server.respondWith("GET", "/test", "Custom Event Sent!"); var btn = make('') htmx.trigger(btn, "htmx:load"); // have to manually trigger the load event for non-AJAX dynamic content btn.click(); this.server.respond(); btn.innerHTML.should.equal("Custom Event Sent!"); }); it('can handle htmx driven events', function () { this.server.respondWith("GET", "/test", "Clicked!"); var btn = make('') htmx.trigger(btn, "htmx:load"); btn.classList.contains("afterSettle").should.equal(false); btn.click(); this.server.respond(); btn.classList.contains("afterSettle").should.equal(true); }); it('can handle htmx error events', function () { this.server.respondWith("GET", "/test", [404, {}, "Bad request"]); var div = make('
') var btn = make('') htmx.trigger(btn, "htmx:load"); btn.click(); this.server.respond(); div.innerHTML.should.equal("Response Status Error Code 404 from /test"); }); it('hyperscript in non-htmx annotated nodes is evaluated', function () { this.server.respondWith("GET", "/test", "
"); var btn = make('') btn.click(); this.server.respond(); var newDiv = byId("d1"); newDiv.click(); newDiv.innerText.should.equal("Clicked..."); }); it('hyperscript removal example works', function (done) { this.server.respondWith("GET", "/test", "
To Remove
"); var btn = make('') btn.click(); this.server.respond(); var newDiv = byId("d1"); newDiv.innerText.should.equal("To Remove") setTimeout(function(){ newDiv = byId("d1"); should.equal(newDiv, null); done(); }, 100); }); });