This page demonstrates some of the experiences that Pragmatic drag and drop enables. These examples use a combination of our core package and optional packages.
List
Simple list on other stacks
We have created simple list example which does not leverage any other Atlassian Design System outputs.
, (opens new window)In order to demonstrate how to use Pragmatic drag and drop on different tech stacks, the community has ported this simple list example to various tech stacks:
List example ports
These examples have been contributed by a mixture of Atlassian and non-Atlassian contributors. Please use caution when viewing and running these examples.
Technologies | Source | Standalone example | Author(s) |
---|---|---|---|
React + TailwindCSS | Github | Run on StackBlitz | @alexandereardon |
TailwindCSS | Github | Run on StackBlitz | @alexandereardon |
SolidJS + TailwindCSS | Github | Run on StackBlitz | @dotnize |
Vue 3 + TailwindCSS | Github | Run on StackBlitz | @frenicohansen |
Vue 3 + Nuxt 3 (SSR) + TailwindCSS | Github | Run on StackBlitz | @frenicohansen |
Board
Board with shadows
A board example that leverages shadows for drop placement (like Trello).
This example does not have our accessibility guidelines wired up to keep the code simpler. It is built on React, TailwindCSS (for styling) and Lucide (for icons).
For Atlassians: please do not leverage shadows for drop placement in Atlassian experiences. Trello being the only exception to this rule.
Shadow based drop placement does not follow our design guidelines that have been agreed on by craft and leadership. Our chosen design affordances have been chosen because they scale well across a huge variety of experiences in a consistent way. This predictability is important for our users. Our chosen affordances are also performant and easy to get right.
Grid
This grid example does a simple "swap" when dropping. You can do whatever operations you like with grids (including inserting items based on closest edge). This example does not currently have accessibility wired up.
Table
Needs updating
Our table example does not line up with our latest design guidelines and needs to be updated.
Status | Description | Assignee |
---|---|---|
In Progress | Generated description 0 | Vania |
Todo | Generated description 1 | Alexander |
In Progress | Generated description 2 | Aliza |
Done | Generated description 3 | Alvin |
In Progress | Generated description 4 | Angie |
Done | Generated description 5 | Arjun |
Done | Generated description 6 | Blair |
Done | Generated description 7 | Claudia |
In Progress | Generated description 8 | Colin |
Todo | Generated description 9 | Ed |
Todo | Generated description 10 | Effie |
Todo | Generated description 11 | Eliot |
Done | Generated description 12 | Fabian |
Todo | Generated description 13 | Gael |
In Progress | Generated description 14 | Gerard |
Todo | Generated description 15 | Hasan |
In Progress | Generated description 16 | Helena |
Todo | Generated description 17 | Ivan |
In Progress | Generated description 18 | Katina |
In Progress | Generated description 19 | Lara |
Tree
File
Use the external adapter to capture files that users drag and drop onto the page.
When requesting files, you should also provide an <input type="file" />
for usability and
accessibility reasons.
Drawing
Excepted from Success Criterion 2.1.1 - Keyboard (Level A)
This example is excepted from the WCAG Success Criterion 2.1.1 - Keyboard (Level A). The underlying function (freehand drawing) requires input that depends on the path of the user's movement and not just the endpoints.
Due to Success Criterion 2.1.3 - Keyboard (No Exception) (Level AAA), path-dependent input cannot meet Guideline 2.1 at Level AAA.
Wherever possible, this exception should not be relied on, and an alternative input method should be provided.
Resizing
Accessibility guidance in progress
An investigation is required to decide on appropriate accessible controls for resizing. If you would like us to prioritise this investigation, please reach out.
Virtual
Pragmatic drag an drop works with any virtual experience: you can add, remove or change any entity you want during a drag operation. This example uses TanStack Virtual, but you can use any virtualization solution you like.
See our virtualization guide for more details.
Iframes and external applications
Pragmatic drag and drop enables you to attach data for external systems (other brower tabs, iframes or even native applications), as well as respond to and recieve data being dragged from external systems.
External example
atlassian.design
currently does not support displaying an example without the page layout, so our
iframe example is hosted on another site.