From f51f33ec2599f19036539b01c08b56fafcc3db05 Mon Sep 17 00:00:00 2001 From: Oleksii Kriuchykhin Date: Wed, 30 Nov 2016 11:42:05 +0100 Subject: [PATCH] Added sorting functionality to samples colunmns dropdown [SCI-695] --- .../javascripts/samples/sample_datatable.js | 29 +++++++++++++++++-- app/assets/stylesheets/themes/scinote.scss | 8 +++++ 2 files changed, 34 insertions(+), 3 deletions(-) diff --git a/app/assets/javascripts/samples/sample_datatable.js b/app/assets/javascripts/samples/sample_datatable.js index c2fcdcd17..1058268d2 100644 --- a/app/assets/javascripts/samples/sample_datatable.js +++ b/app/assets/javascripts/samples/sample_datatable.js @@ -1,3 +1,5 @@ +//= require jquery-ui + var rowsSelected = []; // Tells whether we're currently viewing or editing table @@ -760,8 +762,10 @@ function changeToEditMode() { // loads the columns names in the dropdown list function loadColumnsNames() { + // First, clear the list + dropdownList.find('li[data-position]').remove(); _.each(table.columns().header(), function(el, index) { - if( index > 1 ) { + if (index > 1) { var colIndex = $(el).attr('data-column-index'); var visible = table.column(colIndex).visible(); var visClass = (visible) ? 'glyphicon-eye-open' : 'glyphicon-eye-close'; @@ -776,7 +780,7 @@ function changeToEditMode() { dropdownList.append(html); } }); - + toggleColumnVisibility(); // toggles grip img customLiHoverEffect(); } @@ -816,11 +820,30 @@ function changeToEditMode() { }); } + function initSorting() { + dropdownList.sortable({ + items: 'li:not(.new-samples-column)', + cancel: '.new-samples-column', + axis: 'y', + update: function() { + var reorderer = table.colReorder; + var listIds = []; + // We skip first two columns + listIds.push(0, 1); + dropdownList.find('li[data-position]').each(function() { + listIds.push($(this).first().data('position')); + }); + reorderer.order(listIds, false); + loadColumnsNames(); + } + }); + } + // initialze dropdown after the table is loaded function initDropdown() { table.on('draw.dt', function() { loadColumnsNames(); - toggleColumnVisibility(); + initSorting(); }); } diff --git a/app/assets/stylesheets/themes/scinote.scss b/app/assets/stylesheets/themes/scinote.scss index 9dc3eb7cd..dc08a37fe 100644 --- a/app/assets/stylesheets/themes/scinote.scss +++ b/app/assets/stylesheets/themes/scinote.scss @@ -1590,11 +1590,19 @@ textarea.textarea-sm { width: 300px; li { + background: $color-white; border: 1px solid $color-alto; + cursor: -webkit-grab; + cursor: grab; padding: 10px 10px 10px 0; vertical-align: middle; } + li.ui-sortable-helper { + cursor: -webkit-grabbing; + cursor: grabbing; + } + .vis { cursor: pointer; margin-right: 5px;