Browse Source

+ dev (v0.4.0)

pull/60/head
RubaXa 11 years ago
parent
commit
ea1f6198e8
  1. 2
      Gruntfile.js
  2. 65
      README.md
  3. 77
      Sortable.js
  4. 4
      Sortable.min.js
  5. 2
      bower.json
  6. 2
      component.json
  7. 13
      index.html
  8. 2
      package.json

2
Gruntfile.js

@ -5,7 +5,7 @@ module.exports = function (grunt){
pkg: grunt.file.readJSON('package.json'), pkg: grunt.file.readJSON('package.json'),
version: { version: {
src: ['<%= pkg.exportName %>.js', 'bower.json'] src: ['<%= pkg.exportName %>.js', '*.json']
}, },
uglify: { uglify: {

65
README.md

@ -19,14 +19,19 @@
``` ```
```js ```js
new Sortable(items); var el = document.getElementById('items');
new Sortable(el);
``` ```
---
### Options ### Options
```js ```js
new Sortable(elem, { new Sortable(el, {
group: "name", group: "name",
store: null, // @see Store
handle: ".my-handle", // Restricts sort start click/touch to the specified element handle: ".my-handle", // Restricts sort start click/touch to the specified element
draggable: ".item", // Specifies which items inside the element should be sortable draggable: ".item", // Specifies which items inside the element should be sortable
ghostClass: "sortable-ghost", ghostClass: "sortable-ghost",
@ -53,6 +58,59 @@ new Sortable(elem, {
}); });
``` ```
---
### Method
##### toArray():`String[]`
Serializes the sortable's item data-id's into an array of string.
##### sort(order:`Array`)
Sorts the elements according to the array.
```js
var order = sortable.toArray();
sortable.sort(order.reverse()); // apply
```
##### destroy()
---
### Store
Saving and restoring of the sort.
```js
new Sortable(el, {
group: "localStorage-example",
store: {
/**
* Get the order of elements. Called once during initialization.
* @param {Sortable} sortable
* @retruns {Array}
*/
get: function (sortable) {
var order = localStorage.getItem(sortable.options.group);
return order ? order.split('|') : [];
},
/**
* Save the order of elements. Called every time at the drag end.
* @param {Sortable} sortable
*/
set: function (sortable) {
var order = sortable.toArray();
localStorage.setItem(sortable.options.group, order.join('|'));
}
}
})
```
--- ---
@ -70,6 +128,3 @@ new Sortable(elem, {
* closest(el`:HTMLElement`, selector`:String`[, ctx`:HTMLElement`])`:HTMLElement|Null` — for each element in the set, get the first element that matches the selector by testing the element itself and traversing up through its ancestors in the DOM tree * closest(el`:HTMLElement`, selector`:String`[, ctx`:HTMLElement`])`:HTMLElement|Null` — for each element in the set, get the first element that matches the selector by testing the element itself and traversing up through its ancestors in the DOM tree
* toggleClass(el`:HTMLElement`, name`:String`, state`:Boolean`) — add or remove one classes from each element * toggleClass(el`:HTMLElement`, name`:String`, state`:Boolean`) — add or remove one classes from each element
[![Bitdeli Badge](https://d2weczhvl823v0.cloudfront.net/RubaXa/sortable/trend.png)](https://bitdeli.com/free "Bitdeli Badge")

77
Sortable.js

@ -58,11 +58,11 @@
; ;
/** /**
* @class Sortable * @class Sortable
* @param {HTMLElement} el * @param {HTMLElement} el
* @param {Object} [options] * @param {Object} [options]
* @constructor
*/ */
function Sortable(el, options){ function Sortable(el, options){
this.el = el; // root element this.el = el; // root element
@ -71,6 +71,7 @@
// Defaults // Defaults
options.group = options.group || Math.random(); options.group = options.group || Math.random();
options.store = options.store || null;
options.handle = options.handle || null; options.handle = options.handle || null;
options.draggable = options.draggable || el.children[0] && el.children[0].nodeName || (/[uo]l/i.test(el.nodeName) ? 'li' : '*'); options.draggable = options.draggable || el.children[0] && el.children[0].nodeName || (/[uo]l/i.test(el.nodeName) ? 'li' : '*');
options.ghostClass = options.ghostClass || 'sortable-ghost'; options.ghostClass = options.ghostClass || 'sortable-ghost';
@ -110,10 +111,13 @@
_on(el, 'dragenter', this._onDragOver); _on(el, 'dragenter', this._onDragOver);
touchDragOverListeners.push(this._onDragOver); touchDragOverListeners.push(this._onDragOver);
// Restore sorting
options.store && this.sort(options.store.get(this));
} }
Sortable.prototype = { Sortable.prototype = /** @lends Sortable.prototype */ {
constructor: Sortable, constructor: Sortable,
@ -378,6 +382,7 @@
// Update event // Update event
dragEl.dispatchEvent(_createEvent('update', dragEl)); dragEl.dispatchEvent(_createEvent('update', dragEl));
} }
dragEl.dispatchEvent(_createEvent('stop', dragEl)); dragEl.dispatchEvent(_createEvent('stop', dragEl));
} }
@ -394,10 +399,57 @@
lastCSS = lastCSS =
activeGroup = null; activeGroup = null;
// Save sorting
this.options.store && this.options.store.set(this);
}
},
/**
* Serializes the item into an array of string.
* @returns {String[]}
*/
toArray: function () {
var order = [],
el,
children = this.el.children,
i = 0,
n = children.length
;
for (; i < n; i++) {
el = children[i];
order.push(el.getAttribute('data-id') || _generateId(el));
}
return order;
},
/**
* Sorts the elements according to the array.
* @param {String[]} order order of the items
*/
sort: function (order) {
var items = {}, el = this.el;
this.toArray().forEach(function (id, i) {
items[id] = el.children[i];
});
order.forEach(function (id) {
if (items[id]) {
el.removeChild(items[id]);
el.appendChild(items[id]);
} }
});
}, },
/**
* Destroy
*/
destroy: function () { destroy: function () {
var el = this.el, options = this.options; var el = this.el, options = this.options;
@ -426,6 +478,7 @@
} }
}; };
function _bind(ctx, fn){ function _bind(ctx, fn){
var args = slice.call(arguments, 2); var args = slice.call(arguments, 2);
return fn.bind ? fn.bind.apply(fn, [ctx].concat(args)) : function (){ return fn.bind ? fn.bind.apply(fn, [ctx].concat(args)) : function (){
@ -538,6 +591,23 @@
} }
/**
* Generate id
* @param {HTMLElement} el
* @returns {String}
* @private
*/
function _generateId(el) {
var str = el.innerHTML + el.className + el.src,
i = str.length,
sum = 0
;
while (i--) {
sum += str.charCodeAt(i);
}
return sum.toString(36);
}
// Export utils // Export utils
Sortable.utils = { Sortable.utils = {
@ -551,7 +621,8 @@
}; };
Sortable.version = '0.3.0'; Sortable.version = '0.4.0';
// Export // Export
return Sortable; return Sortable;

4
Sortable.min.js vendored

File diff suppressed because one or more lines are too long

2
bower.json

@ -1,7 +1,7 @@
{ {
"name": "Sortable", "name": "Sortable",
"main": "Sortable.js", "main": "Sortable.js",
"version": "0.3.0", "version": "0.4.0",
"homepage": "http://rubaxa.github.io/Sortable/", "homepage": "http://rubaxa.github.io/Sortable/",
"authors": [ "authors": [
"RubaXa <ibnRubaXa@gmail.com>" "RubaXa <ibnRubaXa@gmail.com>"

2
component.json

@ -1,7 +1,7 @@
{ {
"name": "Sortable", "name": "Sortable",
"main": "Sortable.js", "main": "Sortable.js",
"version": "0.1.9", "version": "0.4.0",
"homepage": "http://rubaxa.github.io/Sortable/", "homepage": "http://rubaxa.github.io/Sortable/",
"repo": "RubaXa/Sortable", "repo": "RubaXa/Sortable",
"authors": [ "authors": [

13
index.html

@ -309,8 +309,18 @@ sort.destroy();
} }
new Sortable(foo, { window.x = new Sortable(foo, {
group: "words", group: "words",
store: {
get: function (sortable) {
var order = localStorage.getItem(sortable.options.group);
return order ? order.split('|') : [];
},
set: function (sortable) {
var order = sortable.toArray();
localStorage.setItem(sortable.options.group, order.join('|'));
}
},
onAdd: function (evt){ console.log('onAdd.foo:', evt.item); }, onAdd: function (evt){ console.log('onAdd.foo:', evt.item); },
onUpdate: function (evt){ console.log('onUpdate.foo:', evt.item); }, onUpdate: function (evt){ console.log('onUpdate.foo:', evt.item); },
onRemove: function (evt){ console.log('onRemove.foo:', evt.item); }, onRemove: function (evt){ console.log('onRemove.foo:', evt.item); },
@ -318,6 +328,7 @@ sort.destroy();
onEnd: function(evt){ console.log('onEnd.foo:', evt.item);} onEnd: function(evt){ console.log('onEnd.foo:', evt.item);}
}); });
new Sortable(bar, { new Sortable(bar, {
group: "words", group: "words",
onAdd: function (evt){ console.log('onAdd.bar:', evt.item); }, onAdd: function (evt){ console.log('onAdd.bar:', evt.item); },

2
package.json

@ -1,7 +1,7 @@
{ {
"name": "sortable", "name": "sortable",
"exportName": "Sortable", "exportName": "Sortable",
"version": "0.3.0", "version": "0.4.0",
"devDependencies": { "devDependencies": {
"grunt": "*", "grunt": "*",
"grunt-version": "*", "grunt-version": "*",

Loading…
Cancel
Save