mirror of
https://github.com/bigskysoftware/htmx.git
synced 2026-01-01 06:11:17 +00:00
40 lines
1.3 KiB
JavaScript
40 lines
1.3 KiB
JavaScript
describe('on() unit tests', function() {
|
|
|
|
it('registers event listener on document by default', function () {
|
|
let called = false
|
|
htmx.on('custom:test', () => called = true)
|
|
document.dispatchEvent(new Event('custom:test'))
|
|
assert.isTrue(called)
|
|
})
|
|
|
|
it('registers event listener on specific element', function () {
|
|
let div = createProcessedHTML('<div></div>')
|
|
let called = false
|
|
htmx.on(div, 'custom', () => called = true)
|
|
div.dispatchEvent(new Event('custom'))
|
|
assert.isTrue(called)
|
|
})
|
|
|
|
it('returns the callback', function () {
|
|
let callback = () => {}
|
|
let returned = htmx.on('custom', callback)
|
|
assert.equal(returned, callback)
|
|
})
|
|
|
|
it('receives event object', function () {
|
|
let receivedEvent = null
|
|
htmx.on('custom:test2', (evt) => receivedEvent = evt)
|
|
document.dispatchEvent(new Event('custom:test2'))
|
|
assert.isNotNull(receivedEvent)
|
|
assert.equal(receivedEvent.type, 'custom:test2')
|
|
})
|
|
|
|
it('works with selector string for element', function () {
|
|
createProcessedHTML('<div id="target"></div>')
|
|
let called = false
|
|
htmx.on('#target', 'custom', () => called = true)
|
|
document.getElementById('target').dispatchEvent(new Event('custom'))
|
|
assert.isTrue(called)
|
|
})
|
|
|
|
}); |