describe('hx-preserve 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', "
New Content
New Content
") var div = make("
Old Content
Old Content
") div.click() this.server.respond() byId('d1').innerHTML.should.equal('Old Content') byId('d2').innerHTML.should.equal('New Content') }) it('handles preserved element that might not be existing', function() { this.server.respondWith('GET', '/test', "
New Content
New Content
") var div = make("
Old Content
") div.click() this.server.respond() byId('d1').innerHTML.should.equal('New Content') byId('d2').innerHTML.should.equal('New Content') }) it('preserved element should not be swapped if it lies outside of hx-select', function() { this.server.respondWith('GET', '/test', "
New Content
New Content
") var div = make("
Old Content
Old Content
") div.click() this.server.respond() byId('d1').innerHTML.should.equal('Old Content') byId('d2').innerHTML.should.equal('New Content') }) it('preserved element should not be swapped if it is part of a oob swap', function() { this.server.respondWith('GET', '/test', "Normal Content
New oob Content
New oob Content
") var div1 = make("
Click Me!
") var div2 = make("
Old Content
") div1.click() this.server.respond() byId('d1').innerHTML.should.equal('Normal Content') byId('d3').innerHTML.should.equal('Old Content') byId('d4').innerHTML.should.equal('New oob Content') }) it('preserved element should not be swapped if it is part of a hx-select-oob swap', function() { this.server.respondWith('GET', '/test', "Normal Content
New oob Content
New oob Content
") var div1 = make("
Click Me!
") var div2 = make("
Old Content
") div1.click() this.server.respond() byId('d1').innerHTML.should.equal('Normal Content') byId('d3').innerHTML.should.equal('Old Content') byId('d4').innerHTML.should.equal('New oob Content') }) it('preserved element should relocated unchanged if it is part of a oob swap targeting a different loction', function() { this.server.respondWith('GET', '/test', "Normal Content
New oob Content
New oob Content
") var div1 = make("
Click Me!
") var div2 = make("
Old Content
") var div5 = make("
") div1.click() this.server.respond() byId('d1').innerHTML.should.equal('Normal Content') byId('d2').innerHTML.should.equal('') byId('d5').innerHTML.should.equal('
Old Content
New oob Content
') }) it('when moveBefore is disabled/missing preseved content is copied into fragment instead of pantry', function() { var div = make("
Old Content
Old Content
") var fragment = htmx._('makeFragment')('
New Content
') fragment.firstChild.moveBefore = undefined htmx._('handlePreservedElements')(fragment) fragment.firstChild.innerHTML.should.equal('Old Content') }) })