paste.js 1.75 KB
"use strict";

Object.defineProperty(exports, "__esModule", {
  value: true
});
exports.paste = paste;

var _dom = require("@testing-library/dom");

var _utils = require("./utils");

function paste(element, text, init, {
  initialSelectionStart,
  initialSelectionEnd
} = {}) {
  if (element.disabled) return;

  if (typeof element.value === 'undefined') {
    throw new TypeError(`the current element is of type ${element.tagName} and doesn't have a valid value`);
  }

  (0, _utils.eventWrapper)(() => element.focus()); // by default, a new element has it's selection start and end at 0
  // but most of the time when people call "paste", they expect it to paste
  // at the end of the current input value. So, if the selection start
  // and end are both the default of 0, then we'll go ahead and change
  // them to the length of the current value.
  // the only time it would make sense to pass the initialSelectionStart or
  // initialSelectionEnd is if you have an input with a value and want to
  // explicitely start typing with the cursor at 0. Not super common.

  if (element.selectionStart === 0 && element.selectionEnd === 0) {
    (0, _utils.setSelectionRangeIfNecessary)(element, initialSelectionStart != null ? initialSelectionStart : element.value.length, initialSelectionEnd != null ? initialSelectionEnd : element.value.length);
  }

  _dom.fireEvent.paste(element, init);

  if (!element.readOnly) {
    const {
      newValue,
      newSelectionStart
    } = (0, _utils.calculateNewValue)(text, element);

    _dom.fireEvent.input(element, {
      inputType: 'insertFromPaste',
      target: {
        value: newValue
      }
    });

    (0, _utils.setSelectionRangeIfNecessary)(element, {
      newSelectionStart,
      newSelectionEnd: newSelectionStart
    });
  }
}