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("")
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("")
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("")
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 ContentNew oob Content
New oob Content
")
var div1 = make("Click Me!
")
var div2 = make("")
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 ContentNew oob Content
New oob Content
")
var div1 = make("Click Me!
")
var div2 = make("")
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 ContentNew oob Content
New oob Content
")
var div1 = make("Click Me!
")
var div2 = make("")
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("")
var fragment = htmx._('makeFragment')('New Content
')
fragment.firstChild.moveBefore = undefined
htmx._('handlePreservedElements')(fragment)
fragment.firstChild.innerHTML.should.equal('Old Content')
})
})