You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
192 lines
4.8 KiB
192 lines
4.8 KiB
import Clipboard from '../src/clipboard'; |
|
|
|
describe('Clipboard', () => { |
|
before(() => { |
|
global.button = document.createElement('button'); |
|
global.button.setAttribute('class', 'btn'); |
|
global.button.setAttribute('data-clipboard-text', 'foo'); |
|
document.body.appendChild(global.button); |
|
|
|
global.span = document.createElement('span'); |
|
global.span.innerHTML = 'bar'; |
|
|
|
global.button.appendChild(span); |
|
|
|
global.event = { |
|
target: global.button, |
|
currentTarget: global.button, |
|
}; |
|
}); |
|
|
|
after(() => { |
|
document.body.innerHTML = ''; |
|
}); |
|
|
|
describe('#resolveOptions', () => { |
|
before(() => { |
|
global.fn = () => {}; |
|
}); |
|
|
|
it('should set action as a function', () => { |
|
let clipboard = new Clipboard('.btn', { |
|
action: global.fn, |
|
}); |
|
|
|
assert.equal(global.fn, clipboard.action); |
|
}); |
|
|
|
it('should set target as a function', () => { |
|
let clipboard = new Clipboard('.btn', { |
|
target: global.fn, |
|
}); |
|
|
|
assert.equal(global.fn, clipboard.target); |
|
}); |
|
|
|
it('should set text as a function', () => { |
|
let clipboard = new Clipboard('.btn', { |
|
text: global.fn, |
|
}); |
|
|
|
assert.equal(global.fn, clipboard.text); |
|
}); |
|
|
|
it('should set container as an object', () => { |
|
let clipboard = new Clipboard('.btn', { |
|
container: document.body, |
|
}); |
|
|
|
assert.equal(document.body, clipboard.container); |
|
}); |
|
|
|
it('should set container as body by default', () => { |
|
let clipboard = new Clipboard('.btn'); |
|
|
|
assert.equal(document.body, clipboard.container); |
|
}); |
|
}); |
|
|
|
describe('#listenClick', () => { |
|
it('should add a click event listener to the passed selector', () => { |
|
let clipboard = new Clipboard('.btn'); |
|
assert.isObject(clipboard.listener); |
|
}); |
|
}); |
|
|
|
describe('#onClick', () => { |
|
it('should init when called', (done) => { |
|
let clipboard = new Clipboard('.btn'); |
|
|
|
clipboard.on('success', () => { |
|
done(); |
|
}); |
|
|
|
clipboard.onClick(global.event); |
|
}); |
|
|
|
it("should use an event's currentTarget when not equal to target", (done) => { |
|
let clipboard = new Clipboard('.btn'); |
|
let bubbledEvent = { |
|
target: global.span, |
|
currentTarget: global.button, |
|
}; |
|
|
|
clipboard.on('success', () => { |
|
done(); |
|
}); |
|
|
|
clipboard.onClick(bubbledEvent); |
|
}); |
|
|
|
it('should throw an exception when target is invalid', (done) => { |
|
try { |
|
const clipboard = new Clipboard('.btn', { |
|
target() { |
|
return null; |
|
}, |
|
}); |
|
|
|
clipboard.onClick(global.event); |
|
} catch (e) { |
|
assert.equal(e.message, 'Invalid "target" value, use a valid Element'); |
|
done(); |
|
} |
|
}); |
|
}); |
|
|
|
describe('#static isSupported', () => { |
|
it('should return the support of the given action', () => { |
|
assert.equal(Clipboard.isSupported('copy'), true); |
|
assert.equal(Clipboard.isSupported('cut'), true); |
|
}); |
|
|
|
it('should return the support of the cut and copy actions', () => { |
|
assert.equal(Clipboard.isSupported(), true); |
|
}); |
|
}); |
|
|
|
describe('#static copy', () => { |
|
it('should copy in an programatic way based on text', () => { |
|
assert.equal(Clipboard.copy('lorem'), 'lorem'); |
|
}); |
|
|
|
it('should copy in an programatic way based on target', () => { |
|
assert.equal(Clipboard.copy(document.querySelector('span')), 'bar'); |
|
}); |
|
}); |
|
|
|
describe('#static cut', () => { |
|
it('should cut in an programatic way based on text', () => { |
|
assert.equal(Clipboard.cut(document.querySelector('span')), 'bar'); |
|
}); |
|
}); |
|
|
|
describe('#destroy', () => { |
|
it('should destroy an existing instance of ClipboardActionDefault', () => { |
|
let clipboard = new Clipboard('.btn'); |
|
|
|
clipboard.onClick(global.event); |
|
clipboard.destroy(); |
|
|
|
assert.equal(clipboard.clipboardAction, null); |
|
}); |
|
}); |
|
|
|
describe('#events', () => { |
|
it('should fire a success event with certain properties', (done) => { |
|
let clipboard = new Clipboard('.btn'); |
|
|
|
clipboard.on('success', (e) => { |
|
assert.property(e, 'action'); |
|
assert.equal(e.action, 'copy'); |
|
assert.property(e, 'text'); |
|
assert.property(e, 'trigger'); |
|
assert.property(e, 'clearSelection'); |
|
|
|
done(); |
|
}); |
|
|
|
clipboard.onClick(global.event); |
|
}); |
|
}); |
|
|
|
describe('#clearSelection', () => { |
|
it('should clear text selection without moving focus', (done) => { |
|
let clipboard = new Clipboard('.btn'); |
|
|
|
clipboard.on('success', (e) => { |
|
e.clearSelection(); |
|
|
|
let selectedElem = document.activeElement; |
|
let selectedText = window.getSelection().toString(); |
|
|
|
assert.equal(selectedElem, e.trigger); |
|
assert.equal(selectedText, ''); |
|
|
|
done(); |
|
}); |
|
|
|
clipboard.onClick(global.event); |
|
}); |
|
}); |
|
});
|
|
|