Gathering detailed insights and metrics for @escola-ch/vue-slicksort
Gathering detailed insights and metrics for @escola-ch/vue-slicksort
A set of vue mixins to turn any list into an animated, touch-friendly, sortable list βοΈ
npm install @escola-ch/vue-slicksort
Typescript
Module System
Node Version
NPM Version
59.2
Supply Chain
98.6
Quality
75.7
Maintenance
100
Vulnerability
100
License
TypeScript (83.93%)
JavaScript (6.99%)
Vue (6.31%)
HTML (2.77%)
Total Downloads
1,049
Last Day
3
Last Week
11
Last Month
75
Last Year
270
560 Commits
1 Branches
1 Contributors
Minified
Minified + Gzipped
Latest Version
2.0.9-alpha.1
Package Id
@escola-ch/vue-slicksort@2.0.9-alpha.1
Unpacked Size
291.87 kB
Size
62.58 kB
File Count
9
NPM Version
9.5.1
Node Version
18.16.0
Publised On
21 Aug 2023
Cumulative downloads
Total Downloads
Last day
50%
3
Compared to previous day
Last week
-69.4%
11
Compared to previous week
Last month
240.9%
75
Compared to previous month
Last year
-65.3%
270
Compared to previous year
1
38
A set of component mixins to turn any list into an animated, touch-friendly, sortable list. Based on react-sortable-hoc by [@clauderic]
v-model
Compatible β Make any array editable with the v-model
standardUsing npm:
$ npm install vue-slicksort --save
Using yarn:
$ yarn add vue-slicksort
Using a CDN:
1<script src="https://unpkg.com/vue-slicksort@latest/dist/vue-slicksort.min.js"></script>
Then, using a module bundler that supports either CommonJS or ES2015 modules, such as webpack:
1// Using an ES6 transpiler like Babel 2import { ContainerMixin, ElementMixin } from 'vue-slicksort'; 3 4// Not using an ES6 transpiler 5var slicksort = require('vue-slicksort'); 6var ContainerMixin = slicksort.ContainerMixin; 7var ElementMixin = slicksort.ElementMixin;
If you are loading the package via <script>
tag:
1<script> 2 var { ContainerMixin, ElementMixin, HandleDirective } = window.VueSlicksort; 3</script>
Check out the docs: vue-slicksort.netlify.app
There are already a number of great Drag & Drop libraries out there (for instance, vuedraggable is fantastic). If those libraries fit your needs, you should definitely give them a try first. However, most of those libraries rely on the HTML5 Drag & Drop API, which has some severe limitations. For instance, things rapidly become tricky if you need to support touch devices, if you need to lock dragging to an axis, or want to animate the nodes as they're being sorted. Vue Slicksort aims to provide a simple set of component mixins to fill those gaps. If you're looking for a dead-simple, mobile-friendly way to add sortable functionality to your lists, then you're in the right place.
There are a few changes in v2, mainly support for Vue 3 and dragging between groups. Read more about migrating here: vue-slicksort.netlify.app/migrating-1x
The event names have all changed from camelCase to dash-case to accommodate for inline HTML templates.
Need to sort items in a grid? We've got you covered! Just set the axis
prop to xy
. Grid support is currently limited to a setup where all the cells in the grid have the same width and height, though we're working hard to get variable width support in the near future.
Upon sorting, vue-slicksort
creates a clone of the element you are sorting (the sortable-helper) and appends it to the end of the appendTo
tag. The original element will still be in-place to preserve its position in the DOM until the end of the drag (with inline-styling to make it invisible). If the sortable-helper gets messed up from a CSS standpoint, consider that maybe your selectors to the draggable item are dependent on a parent element which isn't present anymore (again, since the sortable-helper is at the end of the appendTo
prop). This can also be a z-index
issue, for example, when using vue-slicksort
within a Bootstrap modal, you'll need to increase the z-index
of the SortableHelper so it is displayed on top of the modal.
By default, vue-slicksort
is triggered immediately on mousedown
. If you'd like to prevent this behaviour, there are a number of strategies readily available. You can use the distance
prop to set a minimum distance (in pixels) to be dragged before sorting is enabled. You can also use the pressDelay
prop to add a delay before sorting is enabled. Alternatively, you can also use the HandleDirective.
If you are using scoped styles on the sortable list, you can use appendTo
prop.
Slicksort has no dependencies.
vue
is the only peerDependency
If believe you've found an issue, please report it along with any relevant details to reproduce it. The easiest way to do so is to fork this jsfiddle.
Please file an issue for personal support requests. Tag them with question
.
Yes please! Feature requests / pull requests are welcome.
This library is heavily based on react-sortable-hoc by ClaudΓ©ric Demers (@clauderic). A very simple and low overhead implementation of drag and drop that looks and performs great!
No vulnerabilities found.
No security vulnerabilities found.