Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/xygengcn/vue3-swipe-actions
https://github.com/xygengcn/vue3-swipe-actions
Last synced: 9 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/xygengcn/vue3-swipe-actions
- Owner: xygengcn
- Created: 2023-12-07T08:32:39.000Z (about 1 year ago)
- Default Branch: master
- Last Pushed: 2023-12-07T08:32:42.000Z (about 1 year ago)
- Last Synced: 2024-12-16T02:12:03.250Z (20 days ago)
- Language: JavaScript
- Size: 28.3 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# vue3-swipe-actions
**iOS style swipe actions for Vue 3
## Thanks List:
1、[https://github.com/eCollect/vue-swipe-actions](https://github.com/eCollect/vue-swipe-actions)
2、[https://github.com/suslik90/vue3-swipe-actions](https://github.com/suslik90/vue3-swipe-actions)
## Installation
```
npm install --save vue3-swipe-actions
``````js
import { SwipeList, SwipeOut } from 'vue3-swipe-actions';export default {
components: {
SwipeOut,
SwipeList
}
};
```## Basic Usage
### Import Styles
```javascript
import 'vue3-swipe-actions/dist/index.css';
```### SwipeList
SwipeList component is just a helper for listing multiple SwipeOuts.
#### Props
| Prop | Data Type | Required | Default | Description |
| ------------------- | --------- | -------- | ---------------- | ------------------------------------------------------------ |
| `items` | Array | * | | An array with your data |
| `item-key` | String | | id | Your key for :key when list is v-for-ed, if not found array index will used |
| `disabled` | Boolean | | false | if true items will be disabled, and text selection will be possible (on desktop). adds class ``swipeout--disabled`` |
| `item-disabled` | Function | | `js () => false` | A function that receives the item as parameter and returns true case disabled or false if not |
| `threshold` | Number | | 45 | With that property you can fine tune when actions are considered open |
| `passive-listeners` | Boolean | | false | It defines if the touch events should be registered as passive or not |
| `revealed` | Object | | | An object representing the revealed status of the items, key is the index and the value is either ```left``` or ```right```, use it with the ```.sync``` modifier |#### Events
| Event | Payload | Description |
| ---------------- | ------- | ------------------------------------------------------------ |
| `swipeout:click` | item | Emitted on single click/tap on the item |
| `active` | Boolean | Emitted when the user is opening/closing the any of the actions |#### Methods
| Method | Params | Description |
| -------------- | --------------- | ------------------------------------------------------------ |
| `revealRight` | index (number) | Reveals right actions on given index |
| `revealLeft` | index (number) | Reveals left actions on given index |
| `closeActions` | index (number)? | Closes actions on given index, or all if no index given |
| `isRevealed` | index (number) | Returns the revealed status on a given index, either ```false``` for closed, or ```left``` or ```right``` |### SwipeOut
SwipeOut is the main component, representing a single item with it's actions.
#### Props
| Prop | Data Type | Required | Default | Description |
| ----------- | --------- | -------- | ------- | ------------------------------------------------------------ |
| `disabled` | Boolean | | false | if true items will be disabled, and text selection will be possible (on desktop). adds class ``swipeout--disabled`` |
| `threshold` | Number | | 45 | With that property you can fine tune when actions are considered open |#### Events
| Event | Payload | Description |
| -------- | ------- | ------------------------------------------------------------ |
| `active` | Boolean | Emitted when the user is opening/closing the any of the actions |```html
{{ item.title }}
{{ item.description }}
{{ index }}
list is empty ( filtered or just empty )
```
```js
export default {
components: {
SwipeOut,
SwipeList
},
data() {
return {
enabled: true,
mockSwipeList: [
{
id: 0,
title: "Some title",
description: "some description"
},
{
id: 1,
title: "Some title",
description: "some description"
},
{
id: 2,
title: "Some title",
description: "some description"
}
]
};
},
methods: {
revealFirstRight() {
this.$refs.list.revealRight(0);
},
revealFirstLeft() {
this.$refs.list.revealLeft(0);
},
closeFirst() {
this.$refs.list.closeActions(0);
},
closeAll() {
this.$refs.list.closeActions();
},
remove(item) {
this.mockSwipeList = this.mockSwipeList.filter(i => i !== item);
// console.log(e, 'remove');
},
itemClick(e) {
console.log(e, "item click");
},
fbClick(e) {
console.log(e, "First Button Click");
},
sbClick(e) {
console.log(e, "Second Button Click");
},
},
}
```