Skip to content

Commit

Permalink
Upgrade sortable.js to version 1.13.0 (#74)
Browse files Browse the repository at this point in the history
Upgrade sortable.js to version 1.13.0; Fixes #73
  • Loading branch information
andrie authored Apr 21, 2021
1 parent c540ace commit 81c0400
Show file tree
Hide file tree
Showing 5 changed files with 29 additions and 11 deletions.
6 changes: 6 additions & 0 deletions NEWS.md
Original file line number Diff line number Diff line change
@@ -1,11 +1,17 @@
# sortable 0.4.4.9000

Upgrade sortable.js

* Include `sortable.js` version 1.13.0, as suggested by #73

Bug fixes

* Capture error if bucket_list header is empty #31
* Fix rank-list-item that spills outside the container boundary #68
* Allow bucket_list to have empty header, and capture error better #69

Other changes

* Upgrade tests to `testthat` version 3


Expand Down
2 changes: 1 addition & 1 deletion inst/examples/example_rank_list.R
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

if (interactive()) {
rank_list(
text = "You can drag, drap and re-order these items:",
text = "You can drag, drop and re-order these items:",
labels = c("one", "two", "three", "four", "five"),
input_id = "example_2"
)
Expand Down
26 changes: 19 additions & 7 deletions inst/htmlwidgets/lib/sortable/sortable.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/**!
* Sortable 1.10.2
* Sortable 1.13.0
* @author RubaXa <[email protected]>
* @author owenm <[email protected]>
* @license MIT
Expand Down Expand Up @@ -132,7 +132,7 @@
throw new TypeError("Invalid attempt to spread non-iterable instance");
}

var version = "1.10.2";
var version = "1.13.0";

function userAgent(pattern) {
if (typeof window !== 'undefined' && window.navigator) {
Expand Down Expand Up @@ -314,7 +314,7 @@
if (!el.getBoundingClientRect && el !== window) return;
var elRect, top, left, bottom, right, height, width;

if (el !== window && el !== getWindowScrollingElement()) {
if (el !== window && el.parentNode && el !== getWindowScrollingElement()) {
elRect = el.getBoundingClientRect();
top = elRect.top;
left = elRect.left;
Expand Down Expand Up @@ -754,7 +754,7 @@
target.animatingX = !!translateX;
target.animatingY = !!translateY;
css(target, 'transform', 'translate3d(' + translateX + 'px,' + translateY + 'px,0)');
repaint(target); // repaint
this.forRepaintDummy = repaint(target); // repaint

css(target, 'transition', 'transform ' + duration + 'ms' + (this.options.easing ? ' ' + this.options.easing : ''));
css(target, 'transform', 'translate3d(0,0,0)');
Expand Down Expand Up @@ -792,6 +792,11 @@
}
}

plugins.forEach(function (p) {
if (p.pluginName === plugin.pluginName) {
throw "Sortable: Cannot mount plugin ".concat(plugin.pluginName, " more than once");
}
});
plugins.push(plugin);
},
pluginEvent: function pluginEvent(eventName, sortable, evt) {
Expand Down Expand Up @@ -1235,7 +1240,7 @@
x: 0,
y: 0
},
supportPointer: Sortable.supportPointer !== false && 'PointerEvent' in window,
supportPointer: Sortable.supportPointer !== false && 'PointerEvent' in window && !Safari,
emptyInsertThreshold: 5
};
PluginManager.initializePlugins(this, el, defaults); // Set default options
Expand Down Expand Up @@ -1322,6 +1327,11 @@

if (originalTarget.isContentEditable) {
return;
} // Safari ignores further event handling after mousedown


if (!this.nativeDraggable && Safari && target && target.tagName.toUpperCase() === 'SELECT') {
return;
}

target = closest(target, options.draggable, el, false);
Expand Down Expand Up @@ -2319,7 +2329,7 @@
* Sorts the elements according to the array.
* @param {String[]} order order of the items
*/
sort: function sort(order) {
sort: function sort(order, useAnimation) {
var items = {},
rootEl = this.el;
this.toArray().forEach(function (id, i) {
Expand All @@ -2329,12 +2339,14 @@
items[id] = el;
}
}, this);
useAnimation && this.captureAnimationState();
order.forEach(function (id) {
if (items[id]) {
rootEl.removeChild(items[id]);
rootEl.appendChild(items[id]);
}
});
useAnimation && this.animateAll();
},

/**
Expand Down Expand Up @@ -2433,7 +2445,7 @@
pluginEvent('showClone', this);
if (Sortable.eventCanceled) return; // show clone at dragEl or original position

if (rootEl.contains(dragEl) && !this.options.group.revertClone) {
if (dragEl.parentNode == rootEl && !this.options.group.revertClone) {
rootEl.insertBefore(cloneEl, dragEl);
} else if (nextEl) {
rootEl.insertBefore(cloneEl, nextEl);
Expand Down
2 changes: 1 addition & 1 deletion inst/htmlwidgets/sortable.yaml
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
dependencies:
- name: SortableJS
version: 1.10.2
version: 1.13.0
src: htmlwidgets/lib/sortable
script: sortable.js
4 changes: 2 additions & 2 deletions scripts/download_sortablejs.R
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@


sortable_version <- "1.10.2"
yaml_version <- "1.10.2"
sortable_version <- "1.13.0"
yaml_version <- "1.13.0"


writeLines(
Expand Down

0 comments on commit 81c0400

Please sign in to comment.