Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/smaharj1/vue-drag-and-drop-kanban
A simple kanban board where the items can be dragged and dropped from the list. This is a hybrid implementation of vue-smooth-dnd.
https://github.com/smaharj1/vue-drag-and-drop-kanban
drag-and-drop hacktoberfest javascript kanban vue vue-smooth-dnd
Last synced: 1 day ago
JSON representation
A simple kanban board where the items can be dragged and dropped from the list. This is a hybrid implementation of vue-smooth-dnd.
- Host: GitHub
- URL: https://github.com/smaharj1/vue-drag-and-drop-kanban
- Owner: smaharj1
- License: mit
- Created: 2018-07-13T16:31:57.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2023-03-04T02:45:00.000Z (almost 2 years ago)
- Last Synced: 2025-02-13T01:37:27.377Z (8 days ago)
- Topics: drag-and-drop, hacktoberfest, javascript, kanban, vue, vue-smooth-dnd
- Language: Vue
- Homepage:
- Size: 11.2 MB
- Stars: 194
- Watchers: 5
- Forks: 26
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: .github/CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
![]()
![]()
![]()
![]()
A simple kanban board where the items can be dragged and dropped from the list. This is a hybrid implementation of vue-smooth-dnd.
## Demo
data:image/s3,"s3://crabby-images/64edf/64edf063190522d0de083cead4c7e46bd841980c" alt="GIF Demo"## Usage
#### Installation
To use the vue-drag-n-drop module, you first need to install the module.```
npm install vue-drag-n-drop
```
or
```
yarn add vue-drag-n-drop
```#### Use Case
``` html
import DragDrop from 'vue-drag-n-drop'
import MyComponent from './MyComponent.vue'export default {
components: {
DragDrop,
MyComponent
},
data() {
return {
stories: [
{
title: 'Strategy 101',
description: 'Create a draft of business plan',
time: '3 days',
done: false
},
{
title: 'Strategy 102',
description: 'Finalize the plan',
time: '4 days',
done: false
},
{
title: 'Tech diagram',
description: 'Draw the tech data',
time: '4 days',
done: false
},
{
title: 'Place Holder',
description: 'Data Science Team',
time: '5 days',
done: false
}
],dropGroups: [
{
name: 'Business Team',
children: []
},
{
name: 'Tech Dept',
children: []
},
{
name: 'Marketing Dept',
children: []
}
]
}
},
}```
`MyComponent.vue`
```html
{{data.title}}
{{data.description}}
Mark Done
export default {
name: 'MyComponent',
props: ['data'],
methods: {
markDone() {
this.$emit('done', this.data);
}
}
}```
## Documentation
#### Instantiating the component
To put the component in your code, you can simply run `import DragDrop from 'vue-drag-n-drop';`. Then, use it in the code as:```html
```
`originalData` in the above code is assumed to be a list of string. However, you can also pass in the list of custom objects like this:
```js
[
{
title: 'Strategy 101',
description: 'Create a draft of business plan',
time: '3 days',
done: false
},
{
title: 'Strategy 102',
description: 'Finalize the plan',
time: '4 days',
done: false
}
]
```When you pass your own objects instead of a list of string, you also need to provide a custom component to handle view/action of this object since you can virtually pass any kind of object.
#### Events
When you use the component, you can also listen to some events that happen inside the component like drag, drop, save and cancel```html
```
`save` - This event is triggered when you click save from inside the component. It gives back the final state of the data in corresponding buckets.
`cancel` - This gives you a choice on how to handle the cancellationn event.
`dropInOriginalBucket` - This event is emitted everytime there is a drop event for original bucket. You provides an object with `startIndex`, `endIndex` and `payload`.
`dropInDestinationBucket` - This event is emitted for each dropzone in the destination bucket. First parameter returns the dropzone name and second parameter returns the drop info `startIndex`, `endIndex` and `payload`.
#### Custom Component for list of objects
`vue-drag-n-drop` uses Vue Named Slots. So, the users can pass in custom component that will have access to the data for the single item. You can impolement the slots like below:```html
```
Here, `dd-card` is the slot name. The component provides a `cardData` variable provides the access of a single object from the original data. If slots aren't used, the component assumes that original data is a list of string. This makes it compatible with older version.
#### CSS Modification
To modify the CSS style, you can override these css classes from your component:
```
.vue-drag-n-drop # This holds the whole container..dd-title # Class for modifying the titles
.dd-first-group # Class to modify the first (original) container. It holds the list of
cards.dd-card-ghost # Class provided for drag class by smooth-dnd
.dd-card-ghost-drop # Class provided for drop by smooth-dnd
.dd-result-group # Class to modify the second drop container (Result container)
.dd-drop-container # Class to modify the style of each column for second container
```
## Support for SSR/Nuxt
Currently, Server Side Rendering is **not** supported. To use it in SSR/Nuxt project, you need to specify Nuxt that this plugin needs to render on the client side.To specify Nuxt to render it on client-side, create a JS file under `~/plugins/` or add to existing one:
`~/plugins/vue-drap-n-drop.js`
```
import Vue from 'vue';
import DragDrop from 'vue-drag-n-drop';Vue.use(DragDrop);
```Add the plugin to `nuxt.config.js`
```
plugins: [
{
src: './plugins/vue-drag-n-drop.js',
ssr: false
}
],
```
## Contributions
Feel free to raise an issue or create a Pull Request if you see ways that can improve this library.## Current Contributors
[data:image/s3,"s3://crabby-images/b2e78/b2e7863d761dc1441136749aad2ff033fa46804e" alt=""](https://sourcerer.io/fame/smaharj1/smaharj1/vue-drag-and-drop-kanban/links/0)[data:image/s3,"s3://crabby-images/5864b/5864b99251ad2ffc1ba69715cdbf210503a84536" alt=""](https://sourcerer.io/fame/smaharj1/smaharj1/vue-drag-and-drop-kanban/links/1)[data:image/s3,"s3://crabby-images/8c54e/8c54e22f429e5a43ec61867c6cbfc2b1269f8c31" alt=""](https://sourcerer.io/fame/smaharj1/smaharj1/vue-drag-and-drop-kanban/links/2)[data:image/s3,"s3://crabby-images/1365b/1365b8ecf55ff280ed0f958c26ace32eadf1c8ba" alt=""](https://sourcerer.io/fame/smaharj1/smaharj1/vue-drag-and-drop-kanban/links/3)[data:image/s3,"s3://crabby-images/6e40a/6e40aac2f571f2a8ffc62a32c93261da3febe68c" alt=""](https://sourcerer.io/fame/smaharj1/smaharj1/vue-drag-and-drop-kanban/links/4)[data:image/s3,"s3://crabby-images/daa41/daa415ecd29255b52ed7438a3e38d027c46b312f" alt=""](https://sourcerer.io/fame/smaharj1/smaharj1/vue-drag-and-drop-kanban/links/5)[data:image/s3,"s3://crabby-images/e83f3/e83f3c5f2c1fed8a35d2b47d158bfc2df9aaa0e7" alt=""](https://sourcerer.io/fame/smaharj1/smaharj1/vue-drag-and-drop-kanban/links/6)[data:image/s3,"s3://crabby-images/31925/31925126cb6c0f1bc19790569e0916fcf853bd0e" alt=""](https://sourcerer.io/fame/smaharj1/smaharj1/vue-drag-and-drop-kanban/links/7)## License
[MIT](https://opensource.org/licenses/MIT)