'use strict';
let React;
let ReactDOMClient;
let act;
describe('SyntheticClipboardEvent', () => {
let container;
beforeEach(() => {
React = require('react');
ReactDOMClient = require('react-dom/client');
act = require('internal-test-utils').act;
container = document.createElement('div');
document.body.appendChild(container);
});
afterEach(() => {
document.body.removeChild(container);
container = null;
});
describe('ClipboardEvent interface', () => {
describe('clipboardData', () => {
describe('when event has clipboardData', () => {
it("returns event's clipboardData", async () => {
let expectedCount = 0;
const clipboardData = {
dropEffect: null,
effectAllowed: null,
files: null,
items: null,
types: null,
};
const eventHandler = event => {
expect(event.clipboardData).toBe(clipboardData);
expectedCount++;
};
const root = ReactDOMClient.createRoot(container);
await act(() => {
root.render(
<div
onCopy={eventHandler}
onCut={eventHandler}
onPaste={eventHandler}
/>,
);
});
const div = container.firstChild;
let event;
event = document.createEvent('Event');
event.initEvent('copy', true, true);
event.clipboardData = clipboardData;
await act(() => {
div.dispatchEvent(event);
});
event = document.createEvent('Event');
event.initEvent('cut', true, true);
event.clipboardData = clipboardData;
await act(() => {
div.dispatchEvent(event);
});
event = document.createEvent('Event');
event.initEvent('paste', true, true);
event.clipboardData = clipboardData;
await act(() => {
div.dispatchEvent(event);
});
expect(expectedCount).toBe(3);
});
});
});
});
describe('EventInterface', () => {
it('is able to `preventDefault` and `stopPropagation`', async () => {
let expectedCount = 0;
const eventHandler = event => {
expect(event.isDefaultPrevented()).toBe(false);
event.preventDefault();
expect(event.isDefaultPrevented()).toBe(true);
expect(event.isPropagationStopped()).toBe(false);
event.stopPropagation();
expect(event.isPropagationStopped()).toBe(true);
expectedCount++;
};
const root = ReactDOMClient.createRoot(container);
await act(() => {
root.render(
<div
onCopy={eventHandler}
onCut={eventHandler}
onPaste={eventHandler}
/>,
);
});
const div = container.firstChild;
let event;
event = document.createEvent('Event');
event.initEvent('copy', true, true);
div.dispatchEvent(event);
event = document.createEvent('Event');
event.initEvent('cut', true, true);
div.dispatchEvent(event);
event = document.createEvent('Event');
event.initEvent('paste', true, true);
div.dispatchEvent(event);
expect(expectedCount).toBe(3);
});
});
});