123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212 |
- "use strict";
- function _instanceof(left, right) { if (right != null && typeof Symbol !== "undefined" && right[Symbol.hasInstance]) { return !!right[Symbol.hasInstance](left); } else { return left instanceof right; } }
- function _classCallCheck(instance, Constructor) { if (!_instanceof(instance, Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
- function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
- function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
- window.addEventListener('touchmove', function () {});
- var Sortable =
- /*#__PURE__*/
- function () {
- function Sortable(list, options) {
- _classCallCheck(this, Sortable);
- this.list = typeof list === 'string' ? document.querySelector(list) : list;
- this.items = Array.from(this.list.children);
- this.animation = false;
- this.options = Object.assign({
- animationSpeed: 200,
- animationEasing: 'ease-out'
- }, options || {});
- this.dragStart = this.dragStart.bind(this);
- this.dragMove = this.dragMove.bind(this);
- this.dragEnd = this.dragEnd.bind(this);
- this.list.addEventListener('touchstart', this.dragStart, false);
- this.list.addEventListener('mousedown', this.dragStart, false);
- }
- _createClass(Sortable, [{
- key: "dragStart",
- value: function dragStart(e) {
- var _this = this;
- if (this.animation) return;
- if (e.type === 'mousedown' && e.which !== 1) return;
- if (e.type === 'touchstart' && e.touches.length > 1) return;
- this.handle = null;
- var el = e.target;
- while (el) {
- if (el.hasAttribute('data-sortable-handle')) this.handle = el;
- if (el.hasAttribute('data-sortable-item')) this.item = el;
- if (el.hasAttribute('data-sortable-list')) break;
- el = el.parentElement;
- }
- if (!this.handle) return;
- this.list.style.position = 'relative';
- this.list.style.height = this.list.offsetHeight + 'px';
- this.item.classList.add('is-dragging');
- this.itemHeight = this.items[1].offsetTop;
- this.listHeight = this.list.offsetHeight;
- this.startTouchY = this.getDragY(e);
- this.startTop = this.item.offsetTop;
- var offsetsTop = this.items.map(function (item) {
- return item.offsetTop;
- });
- this.items.forEach(function (item, index) {
- item.style.position = 'absolute';
- item.style.top = 0;
- item.style.left = 0;
- item.style.width = '100%';
- item.style.transform = "translateY(".concat(offsetsTop[index], "px)");
- item.style.zIndex = item == _this.item ? 2 : 1;
- });
- setTimeout(function () {
- _this.items.forEach(function (item) {
- if (_this.item == item) return;
- item.style.transition = "transform ".concat(_this.options.animationSpeed, "ms ").concat(_this.options.animationEasing);
- });
- });
- this.positions = this.items.map(function (item, index) {
- return index;
- });
- this.position = Math.round(this.startTop / this.listHeight * this.items.length);
- this.touch = e.type == 'touchstart';
- window.addEventListener(this.touch ? 'touchmove' : 'mousemove', this.dragMove, {
- passive: false
- });
- window.addEventListener(this.touch ? 'touchend' : 'mouseup', this.dragEnd, false);
- }
- }, {
- key: "dragMove",
- value: function dragMove(e) {
- var _this2 = this;
- if (this.animation) return;
- var top = this.startTop + this.getDragY(e) - this.startTouchY;
- var newPosition = Math.round(top / this.listHeight * this.items.length);
- this.item.style.transform = "translateY(".concat(top, "px)");
- this.positions.forEach(function (index) {
- if (index == _this2.position || index != newPosition) return;
- _this2.swapElements(_this2.positions, _this2.position, index);
- _this2.position = index;
- });
- this.items.forEach(function (item, index) {
- if (item == _this2.item) return;
- item.style.transform = "translateY(".concat(_this2.positions.indexOf(index) * _this2.itemHeight, "px)");
- });
- e.preventDefault();
- }
- }, {
- key: "dragEnd",
- value: function dragEnd(e) {
- var _this3 = this;
- this.animation = true;
- this.item.style.transition = "all ".concat(this.options.animationSpeed, "ms ").concat(this.options.animationEasing);
- this.item.style.transform = "translateY(".concat(this.position * this.itemHeight, "px)");
- this.item.classList.remove('is-dragging');
- setTimeout(function () {
- _this3.list.style.position = '';
- _this3.list.style.height = '';
- _this3.items.forEach(function (item) {
- item.style.top = '';
- item.style.left = '';
- item.style.right = '';
- item.style.position = '';
- item.style.transform = '';
- item.style.transition = '';
- item.style.width = '';
- item.style.zIndex = '';
- });
- _this3.positions.map(function (i) {
- return _this3.list.appendChild(_this3.items[i]);
- });
- _this3.items = Array.from(_this3.list.children);
- _this3.animation = false;
- }, this.options.animationSpeed);
- window.removeEventListener(this.touch ? 'touchmove' : 'mousemove', this.dragMove, {
- passive: false
- });
- window.removeEventListener(this.touch ? 'touchend' : 'mouseup', this.dragEnd, false);
- }
- }, {
- key: "swapElements",
- value: function swapElements(array, a, b) {
- var temp = array[a];
- array[a] = array[b];
- array[b] = temp;
- }
- }, {
- key: "getDragY",
- value: function getDragY(e) {
- return e.touches ? (e.touches[0] || e.changedTouches[0]).pageY : e.pageY;
- }
- }, {
- key: "removeItem",
- value: function removeItem(item) {
- this.items.splice(this.items.indexOf(item),1);
- item.remove();
- }
- }, {
- key: "addItemFrom",
- value: function addItemFrom(input) {
- var value = querySourceRaw(input);
- var inputElement = document.getElementById(input);
- if (inputElement) inputElement.value = '';
- var template = document.createElement('template');
- template.innerHTML =
- '<div class="list__item" data-sortable-item="data-sortable-item" style="">'+
- '<div class="list__item-close" onclick="removeSortableItem(\'#' + this.list.id + '\', this.parentNode);"></div>'+
- '<div class="list__item-content">'+
- '<div class="list__item-title">' + value + '</div>'+
- '</div>'+
- '<div class="list__item-handle" data-sortable-handle="data-sortable-handle"></div>'+
- '</div>'
- var new_item = template.content.firstChild;
- this.list.appendChild(new_item);
- this.items.push(new_item);
- }
- }, {
- key: "getValues",
- value: function getValues() {
- return Array.from(this.items.map(function(item) { return item.children[1].firstChild.innerHTML; }));
- }
- }]);
- return Sortable;
- }();
- var SortableMap = new Map([]);
- function createSortable(list) {
- SortableMap.set(list, new Sortable(list));
- }
- function removeSortableItem(list, item) {
- SortableMap.get(list).removeItem(item);
- }
- function addSortableItemFrom(list, input) {
- SortableMap.get(list).addItemFrom(input);
- }
- function getSortableValues(list) {
- console.log('getSortableValues',list)
- let sortable = SortableMap.get(list)
- if(sortable) {
- return sortable.getValues();
- } else {
- return Array.from([]);
- }
- }
|