Topic: Sortable plugin - more than two connected lists
brightsystems pro premium priority asked 4 years ago
Is there a way to connect more than two sortable lists? I have tried using a class selector instead of id selector (data-mdb-connected-list=".sortable-list"), but it only selects the first element in the collection. I would really appreciate this option as I am rebuilding a project and want to get rid of a bunch of jquery-ui.
Thanks.
brightsystems pro premium priority answered 4 years ago
I tried to make a snippet showing the issue here: https://mdbootstrap.com/snippets/standard/brightsystems/3021137/
Dawid Wajszczuk staff answered 4 years ago
Hi,
I believe that using this jQuery code should help
$(".class").sortable({
connectWith: ".class"
});
More useful examples can be found in our documentation: https://mdbootstrap.com/docs/b4/jquery/plugins/sortable/#docsTabsOverview
Keep coding,
Dawid
brightsystems pro premium priority commented 4 years ago
I am working in MDB5, and there seems to be some differences.
"connectWith" is now "connectedList", and even with only two lists, it does not work with css classes, as the selector points to the first list only.
That is: With two sortable lists with the class ".sortable-list", the code below makes it possible to move elements from the second list to the first, but not the other way around.
$(".sortable-list").sortable({ connectedList: ".sortable-list" });
Dawid Wajszczuk staff answered 4 years ago
Hi,
Currently in MDB5 we don't have the option to connected more than 2 lists in sortable plugin. But I will add this to our ideas list and maybe in the future we will add this option.
Keep coding.
Dawid
Nomi86 answered 4 years ago
zoey daisy answered 4 years ago
mikejela answered 2 years ago
To achieve this, you can use the connected option of the Sortable library. This option takes an array of Sortable elements to connect.
Here's an example of how to connect three sortable lists using the Sortable library:
html Copy code
To connect these three sortable lists, you can use the following JavaScript code:
javascript Copy code var sortable1 = document.getElementById('sortable1'); var sortable2 = document.getElementById('sortable2'); var sortable3 = document.getElementById('sortable3');
new Sortable(sortable1, { group: "shared", connected: [sortable1, sortable2, sortable3] });
new Sortable(sortable2, { group: "shared", connected: [sortable1, sortable2, sortable3] });
new Sortable(sortable3, { group: "shared", connected: [sortable1, sortable2, sortable3] }); In this example, we create three instances of the Sortable library, one for each sortable list, and set the connected option to an array containing all three sortable lists. This tells the Sortable library that these three lists are connected and items can be moved between them.
Note that we also set the group option to "shared" to make sure that only items from the same group can be moved between the lists.
I hope this helps! Let me know if you have any further questions.
mikejela answered 2 years ago
Hi there! Have you tried using the data-mdb-connected-lists attribute instead of data-mdb-connected-list? This attribute allows you to specify multiple lists by separating them with a comma. For example, data-mdb-connected-lists=".sortable-list-1, .sortable-list-2, .sortable-list-3". Hope this helps!
FREE CONSULTATION
Hire our experts to build a dedicated project. We'll analyze your business requirements, for free.
Answered
- User: Pro
- Premium support: Yes
- Technology: MDB Standard
- MDB Version: 3.2.0
- Device: Any
- Browser: Any
- OS: Any
- Provided sample code: No
- Provided link: No
Fatag commented 2 years ago
Group 1 Item 1.1 Item 1.2
Group 2 Item 2.1 Item 2.2 Group 3 Item 3.1 Item 3.2 .