JSPM

  • Created
  • Published
  • Downloads 1107
  • Score
    100M100P100Q112488F

Package Exports

  • vue-fluid-dnd
  • vue-fluid-dnd/style.css

Readme

Icon
vue-fluid-dnd

A fluid, smooth and versatil drag and drop solution for lists on Vue3.

✨ Features

  • Easy to install.
  • Fully customizable.
  • Work with horizontal and vertical list.
  • Mouse 🐭 and touch 👉📱 (mobile, tablet and so on) support.
  • 🔲 Fully tested, typed and reliable.
  • 🔲 Nice documentation and examples.

🚀 Getting Started

  1. Install vue-fluid-dnd:

    # with npm:
    npm i vue-fluid-dnd
    
    # with yarn:
    yarn add vue-fluid-dnd
    
    # with pnpm:
    pnpm i vue-fluid-dnd
    
    # with ultra:
    ultra install vue-fluid-dnd
  2. Import components

    import { Draggable, Droppable } from "vue-fluid-dnd";
  3. Create a list that your want to sort

    // Each element have its own styles or classes and the draggable-id
    const listToSort = ref([
      {
        "draggable-id": "h1",
        number: 1,
        style:
          "color: white; background-color: red; width: 50px; margin: 23px 0;",
      },
      //...
    ]);
  4. Use the components

    //pass setRef to child to have the reference of draggable element
    //pass the direction of the list and droppable id
    <Droppable droppable-id="droppable-id" direction="vertical" :items="list1">
       <div style="width: 40%; background-color: darkgray; display: block">
          <Draggable
          v-for="(element, index) in listToSort"
          v-slot="{ setRef }"
          :draggable-id="element['draggable-id']"
          :index="index"
          >
          <div :ref="setRef" :style="element.style">{{ element.number }}</div>
          </Draggable>
       </div>
    </Droppable>

🤝 Contributing

If you're interested in contributing to vue-fluid-dnd, please read our contributing docs before submitting a pull request CONTRIBUTING.