![require(esm) Backported to Node.js 20, Paving the Way for ESM-Only Packages](https://cdn.sanity.io/images/cgdhsj6q/production/be8ab80c8efa5907bc341c6fefe9aa20d239d890-1600x1097.png?w=400&fit=max&auto=format)
Security News
require(esm) Backported to Node.js 20, Paving the Way for ESM-Only Packages
require(esm) backported to Node.js 20, easing the transition to ESM-only packages and reducing complexity for developers as Node 18 nears end-of-life.
@4tw/cypress-drag-drop
Advanced tools
@4tw/cypress-drag-drop is a Cypress plugin that allows you to easily simulate drag-and-drop interactions in your end-to-end tests. This can be particularly useful for testing applications with complex UI interactions that involve dragging and dropping elements.
Basic Drag and Drop
This feature allows you to drag an element with the ID 'drag-element' and drop it onto an element with the ID 'drop-target'.
cy.get('#drag-element').drag('#drop-target');
Drag and Drop with Offset
This feature allows you to drag an element with the ID 'drag-element' and drop it onto an element with the ID 'drop-target' with specific offsets for the X and Y coordinates.
cy.get('#drag-element').drag('#drop-target', { offsetX: 10, offsetY: 20 });
Drag and Drop with Force
This feature allows you to force the drag-and-drop action even if the element is not visible or interactable.
cy.get('#drag-element').drag('#drop-target', { force: true });
cypress-real-events is a Cypress plugin that provides real user events like click, double-click, and drag-and-drop. It uses the native browser events to simulate user interactions, making it more reliable for certain types of tests compared to @4tw/cypress-drag-drop.
cypress-drag-drop is another Cypress plugin for drag-and-drop interactions. It offers similar functionality to @4tw/cypress-drag-drop but may have different API methods and options for customization.
A cypress child command for drag'n'drop support.
Install using npm:
npm install --save-dev cypress-drag-drop
or yarn
yarn add --dev cypress-drag-drop
Before Cypress is loaded (usually in your commands.js
) put the following line:
require('cypress-drag-drop')
This will register the drag
command.
The drag
command is a child command.
The command only accepts elements.
As the drop target simply pass a selector as string.
In your cypress spec use the command as follows:
describe('Dragtest', () => {
it('should dragndrop', () => {
cy.visit('/yourpage');
cy.get('.sourceitem').drag('.targetitem');
});
});
The drag command also accepts a position
argument to decide at which position
the element should be dropped.
Possible values are topLeft, top, topRight, left, center, right, bottomLeft, bottom, and bottomRight.
The default position is top
.
describe('Dragtest', () => {
it('should dragndrop', () => {
cy.visit('/yourpage');
cy.get('.sourceitem').drag('.targetitem', 'bottom');
});
});
FAQs
A cypress child command for drag'n'drop support.
The npm package @4tw/cypress-drag-drop receives a total of 153,088 weekly downloads. As such, @4tw/cypress-drag-drop popularity was classified as popular.
We found that @4tw/cypress-drag-drop demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 8 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
require(esm) backported to Node.js 20, easing the transition to ESM-only packages and reducing complexity for developers as Node 18 nears end-of-life.
Security News
PyPI now supports iOS and Android wheels, making it easier for Python developers to distribute mobile packages.
Security News
Create React App is officially deprecated due to React 19 issues and lack of maintenance—developers should switch to Vite or other modern alternatives.