|
|
|
/* DRAG SLIDER
|
|
|
|
================================================== */
|
|
|
|
if(typeof VMM != 'undefined' && typeof VMM.DragSlider == 'undefined') {
|
|
|
|
// VMM.DragSlider.createSlidePanel(drag_object, move_object, w, padding, sticky);
|
|
|
|
// VMM.DragSlider.cancelSlide();
|
|
|
|
|
|
|
|
VMM.DragSlider = function() {
|
|
|
|
var drag = {
|
|
|
|
element: "",
|
|
|
|
element_move: "",
|
|
|
|
constraint: "",
|
|
|
|
sliding: false,
|
|
|
|
pagex: {
|
|
|
|
start: 0,
|
|
|
|
end: 0
|
|
|
|
},
|
|
|
|
left: {
|
|
|
|
start: 0,
|
|
|
|
end: 0
|
|
|
|
},
|
|
|
|
time: {
|
|
|
|
start: 0,
|
|
|
|
end: 0
|
|
|
|
},
|
|
|
|
touch: false,
|
|
|
|
ease: "easeOutExpo"
|
|
|
|
},
|
|
|
|
dragevent = {
|
|
|
|
down: "mousedown",
|
|
|
|
up: "mouseup",
|
|
|
|
leave: "mouseleave",
|
|
|
|
move: "mousemove"
|
|
|
|
},
|
|
|
|
mousedrag = {
|
|
|
|
down: "mousedown",
|
|
|
|
up: "mouseup",
|
|
|
|
leave: "mouseleave",
|
|
|
|
move: "mousemove"
|
|
|
|
},
|
|
|
|
touchdrag = {
|
|
|
|
down: "touchstart",
|
|
|
|
up: "touchend",
|
|
|
|
leave: "mouseleave",
|
|
|
|
move: "touchmove"
|
|
|
|
};
|
|
|
|
|
|
|
|
this.createPanel = function(drag_object, move_object, constraint, touch) {
|
|
|
|
drag.element = drag_object;
|
|
|
|
drag.element_move = move_object;
|
|
|
|
|
|
|
|
if ( constraint != null && constraint != "") {
|
|
|
|
drag.constraint = constraint;
|
|
|
|
} else {
|
|
|
|
drag.constraint = false;
|
|
|
|
}
|
|
|
|
if ( touch) {
|
|
|
|
drag.touch = touch;
|
|
|
|
} else {
|
|
|
|
drag.touch = false;
|
|
|
|
}
|
|
|
|
trace("TOUCH" + drag.touch);
|
|
|
|
if (drag.touch) {
|
|
|
|
dragevent = touchdrag;
|
|
|
|
} else {
|
|
|
|
dragevent = mousedrag;
|
|
|
|
}
|
|
|
|
|
|
|
|
makeDraggable(drag.element, drag.element_move);
|
|
|
|
}
|
|
|
|
|
|
|
|
this.updateConstraint = function(constraint) {
|
|
|
|
trace("updateConstraint");
|
|
|
|
drag.constraint = constraint;
|
|
|
|
}
|
|
|
|
|
|
|
|
var makeDraggable = function(drag_object, move_object) {
|
|
|
|
|
|
|
|
VMM.bindEvent(drag_object, onDragStart, dragevent.down, {element: move_object, delement: drag_object});
|
|
|
|
VMM.bindEvent(drag_object, onDragEnd, dragevent.up, {element: move_object, delement: drag_object});
|
|
|
|
VMM.bindEvent(drag_object, onDragLeave, dragevent.leave, {element: move_object, delement: drag_object});
|
|
|
|
|
|
|
|
}
|
|
|
|
this.cancelSlide = function(e) {
|
|
|
|
VMM.unbindEvent(drag.element, onDragMove, dragevent.move);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
var onDragLeave = function(e) {
|
|
|
|
VMM.unbindEvent(e.data.delement, onDragMove, dragevent.move);
|
|
|
|
if (!drag.touch) {
|
|
|
|
e.preventDefault();
|
|
|
|
}
|
|
|
|
e.stopPropagation();
|
|
|
|
if (drag.sliding) {
|
|
|
|
drag.sliding = false;
|
|
|
|
dragEnd(e.data.element, e.data.delement, e);
|
|
|
|
return false;
|
|
|
|
} else {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
var onDragStart = function(e) {
|
|
|
|
dragStart(e.data.element, e.data.delement, e);
|
|
|
|
if (!drag.touch) {
|
|
|
|
e.preventDefault();
|
|
|
|
}
|
|
|
|
e.stopPropagation();
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
var onDragEnd = function(e) {
|
|
|
|
if (!drag.touch) {
|
|
|
|
e.preventDefault();
|
|
|
|
}
|
|
|
|
e.stopPropagation();
|
|
|
|
if (drag.sliding) {
|
|
|
|
drag.sliding = false;
|
|
|
|
dragEnd(e.data.element, e.data.delement, e);
|
|
|
|
return false;
|
|
|
|
} else {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
var onDragMove = function(e) {
|
|
|
|
dragMove(e.data.element, e);
|
|
|
|
e.preventDefault();
|
|
|
|
e.stopPropagation();
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
var dragStart = function(elem, delem, e) {
|
|
|
|
if (drag.touch) {
|
|
|
|
trace("IS TOUCH")
|
|
|
|
VMM.Lib.css(elem, '-webkit-transition-duration', '0');
|
|
|
|
drag.pagex.start = e.originalEvent.touches[0].screenX;
|
|
|
|
} else {
|
|
|
|
drag.pagex.start = e.pageX;
|
|
|
|
}
|
|
|
|
drag.left.start = getLeft(elem);
|
|
|
|
drag.time.start = new Date().getTime();
|
|
|
|
|
|
|
|
VMM.Lib.stop(elem);
|
|
|
|
VMM.bindEvent(delem, onDragMove, dragevent.move, {element: elem});
|
|
|
|
|
|
|
|
}
|
|
|
|
var dragEnd = function(elem, delem, e) {
|
|
|
|
VMM.unbindEvent(delem, onDragMove, dragevent.move);
|
|
|
|
dragMomentum(elem, e);
|
|
|
|
}
|
|
|
|
var dragMove = function(elem, e) {
|
|
|
|
drag.sliding = true;
|
|
|
|
if (drag.touch) {
|
|
|
|
drag.pagex.end = e.originalEvent.touches[0].screenX;
|
|
|
|
} else {
|
|
|
|
drag.pagex.end = e.pageX;
|
|
|
|
}
|
|
|
|
drag.left.end = getLeft(elem);
|
|
|
|
VMM.Lib.css(elem, 'left', -(drag.pagex.start - drag.pagex.end - drag.left.start));
|
|
|
|
|
|
|
|
}
|
|
|
|
var dragMomentum = function(elem, e) {
|
|
|
|
var drag_info = {
|
|
|
|
left: drag.left.end,
|
|
|
|
left_adjust: 0,
|
|
|
|
change: {
|
|
|
|
x: 0
|
|
|
|
},
|
|
|
|
time: (new Date().getTime() - drag.time.start) * 10,
|
|
|
|
time_adjust: (new Date().getTime() - drag.time.start) * 10
|
|
|
|
},
|
|
|
|
multiplier = 3000;
|
|
|
|
|
|
|
|
if (drag.touch) {
|
|
|
|
multiplier = 6000;
|
|
|
|
}
|
|
|
|
|
|
|
|
drag_info.change.x = multiplier * (Math.abs(drag.pagex.end) - Math.abs(drag.pagex.start));
|
|
|
|
|
|
|
|
|
|
|
|
drag_info.left_adjust = Math.round(drag_info.change.x / drag_info.time);
|
|
|
|
|
|
|
|
drag_info.left = Math.min(drag_info.left + drag_info.left_adjust);
|
|
|
|
|
|
|
|
if (drag.constraint) {
|
|
|
|
if (drag_info.left > drag.constraint.left) {
|
|
|
|
drag_info.left = drag.constraint.left;
|
|
|
|
if (drag_info.time > 5000) {
|
|
|
|
drag_info.time = 5000;
|
|
|
|
}
|
|
|
|
} else if (drag_info.left < drag.constraint.right) {
|
|
|
|
drag_info.left = drag.constraint.right;
|
|
|
|
if (drag_info.time > 5000) {
|
|
|
|
drag_info.time = 5000;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
VMM.fireEvent(elem, "DRAGUPDATE", [drag_info]);
|
|
|
|
|
|
|
|
|
|
|
|
if (drag_info.time > 0) {
|
|
|
|
if (drag.touch) {
|
|
|
|
//VMM.Lib.css(elem, '-webkit-transition-property', 'left');
|
|
|
|
//VMM.Lib.css(elem, '-webkit-transition-duration', drag_info.time);
|
|
|
|
//VMM.Lib.css(elem, 'left', drag_info.left);
|
|
|
|
|
|
|
|
//VMM.Lib.animate(elem, drag_info.time, "easeOutQuad", {"left": drag_info.left});
|
|
|
|
VMM.Lib.animate(elem, drag_info.time, "easeOutCirc", {"left": drag_info.left});
|
|
|
|
//VMM.Lib.css(elem, 'webkitTransition', '');
|
|
|
|
//VMM.Lib.css(elem, 'webkitTransition', '-webkit-transform ' + drag_info.time + 'ms cubic-bezier(0.33, 0.66, 0.66, 1)');
|
|
|
|
//VMM.Lib.css(elem, 'webkitTransform', 'translate3d(' + drag_info.left + 'px, 0, 0)');
|
|
|
|
|
|
|
|
} else {
|
|
|
|
VMM.Lib.animate(elem, drag_info.time, drag.ease, {"left": drag_info.left});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
var getLeft = function(elem) {
|
|
|
|
return parseInt(VMM.Lib.css(elem, 'left').substring(0, VMM.Lib.css(elem, 'left').length - 2), 10);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|