123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243 |
- import ClipboardAction from '../src/clipboard-action';
- import Emitter from 'tiny-emitter';
- describe('ClipboardAction', () => {
- before(() => {
- global.input = document.createElement('input');
- global.input.setAttribute('id', 'input');
- global.input.setAttribute('value', 'abc');
- document.body.appendChild(global.input);
- global.paragraph = document.createElement('p');
- global.paragraph.setAttribute('id', 'paragraph');
- global.paragraph.textContent = 'abc';
- document.body.appendChild(global.paragraph);
- });
- after(() => {
- document.body.innerHTML = '';
- });
- describe('#resolveOptions', () => {
- it('should set base properties', () => {
- let clip = new ClipboardAction({
- emitter: new Emitter(),
- container: document.body,
- text: 'foo'
- });
- assert.property(clip, 'action');
- assert.property(clip, 'container');
- assert.property(clip, 'emitter');
- assert.property(clip, 'target');
- assert.property(clip, 'text');
- assert.property(clip, 'trigger');
- assert.property(clip, 'selectedText');
- });
- });
- describe('#initSelection', () => {
- it('should set the position right style property', done => {
- // Set document direction
- document.documentElement.setAttribute('dir', 'rtl');
- let clip = new ClipboardAction({
- emitter: new Emitter(),
- container: document.body,
- text: 'foo'
- });
- assert.equal(clip.fakeElem.style.right, '-9999px');
- done();
- });
- });
- describe('#set action', () => {
- it('should throw an error since "action" is invalid', done => {
- try {
- new ClipboardAction({
- text: 'foo',
- action: 'paste'
- });
- }
- catch(e) {
- assert.equal(e.message, 'Invalid "action" value, use either "copy" or "cut"');
- done();
- }
- });
- });
- describe('#set target', () => {
- it('should throw an error since "target" do not match any element', done => {
- try {
- new ClipboardAction({
- target: document.querySelector('#foo')
- });
- }
- catch(e) {
- assert.equal(e.message, 'Invalid "target" value, use a valid Element');
- done();
- }
- });
- });
- describe('#selectText', () => {
- it('should create a fake element and select its value', () => {
- let clip = new ClipboardAction({
- emitter: new Emitter(),
- container: document.body,
- text: 'blah'
- });
- assert.equal(clip.selectedText, clip.fakeElem.value);
- });
- });
- describe('#removeFake', () => {
- it('should remove a temporary fake element', () => {
- let clip = new ClipboardAction({
- emitter: new Emitter(),
- container: document.body,
- text: 'blah'
- });
- clip.removeFake();
- assert.equal(clip.fakeElem, null);
- });
- });
- describe('#selectTarget', () => {
- it('should select text from editable element', () => {
- let clip = new ClipboardAction({
- emitter: new Emitter(),
- container: document.body,
- target: document.querySelector('#input')
- });
- assert.equal(clip.selectedText, clip.target.value);
- });
- it('should select text from non-editable element', () => {
- let clip = new ClipboardAction({
- emitter: new Emitter(),
- container: document.body,
- target: document.querySelector('#paragraph')
- });
- assert.equal(clip.selectedText, clip.target.textContent);
- });
- });
- describe('#copyText', () => {
- before(() => {
- global.stub = sinon.stub(document, 'execCommand');
- });
- after(() => {
- global.stub.restore();
- });
- it('should fire a success event on browsers that support copy command', done => {
- global.stub.returns(true);
- let emitter = new Emitter();
- emitter.on('success', () => {
- done();
- });
- let clip = new ClipboardAction({
- emitter,
- target: document.querySelector('#input')
- });
- });
- it('should fire an error event on browsers that support copy command', done => {
- global.stub.returns(false);
- let emitter = new Emitter();
- emitter.on('error', () => {
- done();
- });
- let clip = new ClipboardAction({
- emitter,
- target: document.querySelector('#input')
- });
- });
- });
- describe('#handleResult', () => {
- it('should fire a success event with certain properties', done => {
- let clip = new ClipboardAction({
- emitter: new Emitter(),
- container: document.body,
- target: document.querySelector('#input')
- });
- clip.emitter.on('success', (e) => {
- assert.property(e, 'action');
- assert.property(e, 'text');
- assert.property(e, 'trigger');
- assert.property(e, 'clearSelection');
- done();
- });
- clip.handleResult(true);
- });
- it('should fire a error event with certain properties', done => {
- let clip = new ClipboardAction({
- emitter: new Emitter(),
- container: document.body,
- target: document.querySelector('#input')
- });
- clip.emitter.on('error', (e) => {
- assert.property(e, 'action');
- assert.property(e, 'trigger');
- assert.property(e, 'clearSelection');
- done();
- });
- clip.handleResult(false);
- });
- });
- describe('#clearSelection', () => {
- it('should remove focus from target and text selection', () => {
- let clip = new ClipboardAction({
- emitter: new Emitter(),
- container: document.body,
- target: document.querySelector('#input')
- });
- clip.clearSelection();
- let selectedElem = document.activeElement;
- let selectedText = window.getSelection().toString();
- assert.equal(selectedElem, document.body);
- assert.equal(selectedText, '');
- });
- });
- describe('#destroy', () => {
- it('should destroy an existing fake element', () => {
- let clip = new ClipboardAction({
- emitter: new Emitter(),
- container: document.body,
- text: 'blah'
- });
- clip.selectFake();
- clip.destroy();
- assert.equal(clip.fakeElem, null);
- });
- });
- });
|