Jquery UI sorting multiple table row at once -


i have problem jqueryui sorting.

now have table sorting on tr , it's working, have sort 2 row @ once. in example below have sort row g1 or g2 or g3.

now after having beaten head against wall hours i'm here ask help.

queryui sort have option item, try use can't make itwork in table.

there way that? can me?

i try here https://jsfiddle.net/n29ekt42/

    <table>     <thead>         <tr>             <th>t1</th>             <th>t1</th>             <th>t1</th>         </tr>     </thead>     <tbody>         <tr>             <td>g1</td>             <td>g1</td>             <td>g1</td>         </tr>         <tr>             <td>g1</td>             <td>g1</td>             <td>g1</td>         </tr>         <tr>             <td>g2</td>             <td>g2</td>             <td>g2</td>         </tr>         <tr>             <td>g2</td>             <td>g2</td>             <td>g2</td>         </tr>         <tr>             <td>g3</td>             <td>g3</td>             <td>g3</td>         </tr>         <tr>             <td>g3</td>             <td>g3</td>             <td>g3</td>         </tr>     </tbody>     </table>     function assignsortattach() {      $("table tbody").sortable({         start: function( event, ui ) {             var aa = $this.attr('data-row');         }     }) }  // tr sortable $(function () {     assignsortattach() }); 

i found more difficult anticipated, took stab @ it. forked fiddle , made updates.

working example: https://jsfiddle.net/twisty/n29ekt42/13/

i added handle column.

html

<table>   <thead>     <tr>       <th></th>       <th>t1</th>       <th>t1</th>       <th>t1</th>     </tr>   </thead>   <tbody>     <tr>       <td><span class="handle ui-icon ui-icon-grip-dotted-vertical"></span></td>       <td>g1</td>       <td>g1</td>       <td>g1</td>     </tr> ... 

lots of css, if like.

css

table {   border-collapse: collapse; }  table thead tr {   margin-left: 20px; }  table tbody tr {   border: 1px solid #ccc; }  tr.ui-selecting {   background: #feca40; }  tr.ui-selected {   background: #f39814;   color: white; }  .hidden {   display: none; } 

jquery

function assignsortattach() {   $("table tbody").sortable({       axis: "y",       cursor: "grabbing",       handle: ".handle",       opacity: 0.6,       helper: function(e, item) {         console.log("parent-helper: ", item);         if (!item.hasclass("ui-selected")) {           item.addclass("ui-selected");         }         // clone selected elements         var elements = $(".ui-selected").not('.ui-sortable-placeholder').clone();         console.log("making helper: ", elements);         // hide selected elements         item.siblings(".ui-selected").addclass("hidden");         var helper = $("<table />");         helper.append(elements);         console.log("helper: ", helper);         return helper;       },       start: function(e, ui) {         var elements = ui.item.siblings(".ui-selected.hidden").not('.ui-sortable-placeholder');         ui.item.data("items", elements);       },       update: function(e, ui) {         console.log("receiving: ", ui.item.data("items"));         $.each(ui.item.data("items"), function(k, v) {           console.log("appending ", v, " before ", ui.item);           ui.item.before(v);         });       },       stop: function(e, ui) {         ui.item.siblings(".ui-selected").removeclass("hidden");         $("tr.ui-selected").removeclass("ui-selected");       }     })     .selectable({       filter: "tr",       cancel: ".handle"     }) }  $(function() {   assignsortattach(); }); 

this adapted code here: jquery sortable - drag , drop multiple items , here: jquery ui sortable & selectable

credit using sort , select goes mhu. works well, since can drag-select or ctrl+click select rows like. can drag , select group or click unqiue items group ion drag. using drag handle, user can sort selected rows.

tj gives ability sort multiple items. demo designed move elements between separate lists, switched events receive update.

from flippant comment answer, hope helps.

updates after comments


working example: https://jsfiddle.net/twisty/lbu7ytbj/

i change html group rows:

<table>   <thead>     <tr>       <th>&nbsp;</th>       <th>t1</th>       <th>t1</th>       <th>t1</th>     </tr>   </thead>   <tbody>     <tr>       <td rowspan="2"><span data-group="1" class="handle ui-icon ui-icon-grip-dotted-vertical"></span></td>       <td>g1</td>       <td>g1</td>       <td>g1</td>     </tr>     <tr>       <td>g1</td>       <td>g1</td>       <td>g1</td>     </tr>     </tbody>     <tbody>     <tr>       <td rowspan="2"><span data-group="3" class="handle ui-icon ui-icon-grip-dotted-vertical"></span></td>       <td>g2</td>       <td>g2</td>       <td>g2</td>     </tr>     <tr>       <td>g2</td>       <td>g2</td>       <td>g2</td>     </tr>     </tbody>     <tbody>     <tr>       <td rowspan="2"><span data-group="5" class="handle ui-icon ui-icon-grip-dotted-vertical"></span></td>       <td>g3</td>       <td>g3</td>       <td>g3</td>     </tr>     <tr>       <td>g3</td>       <td>g3</td>       <td>g3</td>     </tr>   </tbody> </table> 

now had adjust sortable use table , not use thead.

function assignsortattach() {   $("table").sortable({     axis: "y",     cursor: "grabbing",     handle: ".handle",     cancel: "thead",     opacity: 0.6,     placeholder: "two-place",     helper: function(e, item) {       if (!item.hasclass("selected")) {         item.addclass("selected");       }       console.log("selected: ", $(".selected"));       var elements = $(".selected").not(".ui-sortable-placeholder").clone();       console.log("making helper from: ", elements);       // hide selected elements       $(".selected").not(".ui-sortable-placeholder").addclass("hidden");       var helper = $("<table />");       helper.append(elements);       console.log("helper: ", helper);       return helper;     },     start: function(e, ui) {       var elements = $(".selected.hidden").not('.ui-sortable-placeholder');       console.log("start: ", elements);       ui.item.data("items", elements);     },     update: function(e, ui) {       console.log("receiving: ", ui.item.data("items"));       ui.item.before(ui.item.data("items")[1], ui.item.data("items")[0]);     },     stop: function(e, ui) {       $('.selected.hidden').not('.ui-sortable-placeholder').removeclass('hidden');       $('.selected').removeclass('selected');     }   }); }  $(function() {   assignsortattach();   $(".handle").attr("title", "use me drag , sort."); }); 

i added css placeholder:

.two-place {   display: block;   visibility: visible;   height: 2.5em;   width: 0; }  .two-place::after {   content: "";   border: 1px dashed #ccc;   float: left;   background-color: #eee;   height: 2.5em;   width: 100px; } 

Comments

Popular posts from this blog

sequelize.js - Sequelize group by with association includes id -

java - Android raising EPERM (Operation not permitted) when attempting to send UDP packet after network connection -

c++ - Migration from QScriptEngine to QJSEngine -