30 lines
1.3 KiB
JavaScript
30 lines
1.3 KiB
JavaScript
import '../utils/click/isClickableInput.js';
|
|
import { createDataTransfer } from '../utils/dataTransfer/DataTransfer.js';
|
|
import { readDataTransferFromClipboard } from '../utils/dataTransfer/Clipboard.js';
|
|
import '../utils/edit/isEditable.js';
|
|
import '../utils/edit/maxLength.js';
|
|
import { getWindow } from '../utils/misc/getWindow.js';
|
|
import '../utils/keyDef/readNextDescriptor.js';
|
|
import '../utils/misc/level.js';
|
|
import '../options.js';
|
|
|
|
async function paste(clipboardData) {
|
|
const doc = this.config.document;
|
|
var _doc_activeElement;
|
|
const target = (_doc_activeElement = doc.activeElement) !== null && _doc_activeElement !== void 0 ? _doc_activeElement : /* istanbul ignore next */ doc.body;
|
|
var _ref;
|
|
const dataTransfer = (_ref = typeof clipboardData === 'string' ? getClipboardDataFromString(doc, clipboardData) : clipboardData) !== null && _ref !== void 0 ? _ref : await readDataTransferFromClipboard(doc).catch(()=>{
|
|
throw new Error('`userEvent.paste()` without `clipboardData` requires the `ClipboardAPI` to be available.');
|
|
});
|
|
this.dispatchUIEvent(target, 'paste', {
|
|
clipboardData: dataTransfer
|
|
});
|
|
}
|
|
function getClipboardDataFromString(doc, text) {
|
|
const dt = createDataTransfer(getWindow(doc));
|
|
dt.setData('text', text);
|
|
return dt;
|
|
}
|
|
|
|
export { paste };
|