clipboard.js 4.8 KB
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);
    });
  });
});