444 lines
13 KiB
JavaScript
444 lines
13 KiB
JavaScript
// Generated by CoffeeScript 1.7.1
|
|
(function(WIN, DOC) {
|
|
var CSS_PREFIX_MAP, DOWN, END_EVENT, IsTouch, LEFT, MAX_OPP_ALLOW_DISTANCE, MIN_ALLOW_DISTANCE, MOVE_EVENT, NULL, NUMBER_REG, RIGHT, START_EVENT, Slip, UNDEFINED, UP, WINDOW_HEIGHT, WINDOW_WIDTH, X, XY, Y, entry, getTranslate, noop, setTransition, setTranslate;
|
|
UNDEFINED = void 0;
|
|
NULL = null;
|
|
X = "x";
|
|
Y = "y";
|
|
XY = "xy";
|
|
LEFT = "left";
|
|
RIGHT = "right";
|
|
UP = "up";
|
|
DOWN = "down";
|
|
MIN_ALLOW_DISTANCE = 10;
|
|
MAX_OPP_ALLOW_DISTANCE = 40;
|
|
CSS_PREFIX_MAP = ["webkit", "moz", "ms", "o", ""];
|
|
NUMBER_REG = /\-?[0-9]+\.?[0-9]*/g;
|
|
IsTouch = 'ontouchend' in WIN;
|
|
START_EVENT = IsTouch ? 'touchstart' : 'mousedown';
|
|
MOVE_EVENT = IsTouch ? 'touchmove' : 'mousemove';
|
|
END_EVENT = IsTouch ? 'touchend' : 'mouseup';
|
|
WINDOW_HEIGHT = WIN['innerHeight'];
|
|
WINDOW_WIDTH = WIN['innerWidth'];
|
|
noop = function() {};
|
|
setTransition = function(ele, css) {
|
|
var name, prefix, _i, _len, _results;
|
|
_results = [];
|
|
for (_i = 0, _len = CSS_PREFIX_MAP.length; _i < _len; _i++) {
|
|
prefix = CSS_PREFIX_MAP[_i];
|
|
name = prefix ? "" + prefix + "Transition" : "transition";
|
|
_results.push(ele.style[name] = css);
|
|
}
|
|
return _results;
|
|
};
|
|
setTranslate = function(ele, x, y, z) {
|
|
var name, prefix, _i, _len, _results;
|
|
_results = [];
|
|
for (_i = 0, _len = CSS_PREFIX_MAP.length; _i < _len; _i++) {
|
|
prefix = CSS_PREFIX_MAP[_i];
|
|
name = prefix ? "" + prefix + "Transform" : "transform";
|
|
_results.push(ele.style[name] = "translate3d(" + (x || 0) + "px, " + (y || 0) + "px, " + (z || 0) + "px)");
|
|
}
|
|
return _results;
|
|
};
|
|
getTranslate = function(ele) {
|
|
var coord, css, name, prefix, translate, _i, _len;
|
|
translate = [];
|
|
css = '';
|
|
coord = '';
|
|
for (_i = 0, _len = CSS_PREFIX_MAP.length; _i < _len; _i++) {
|
|
prefix = CSS_PREFIX_MAP[_i];
|
|
name = prefix ? "" + prefix + "Transform" : "transform";
|
|
css = ele.style[name];
|
|
if (css && typeof css === 'string') {
|
|
coord = css.match(/\((.*)\)/g)[0];
|
|
translate = coord && coord.match(NUMBER_REG);
|
|
break;
|
|
}
|
|
}
|
|
if (translate.length) {
|
|
return {
|
|
x: translate[0] || 0,
|
|
y: translate[1] || 0,
|
|
z: translate[2] || 0
|
|
};
|
|
}
|
|
};
|
|
Slip = (function() {
|
|
var getCoordinates, getCoordinatesArray;
|
|
|
|
getCoordinatesArray = [
|
|
function(event) {
|
|
var e, touches;
|
|
touches = event.touches && (event.touches.length ? event.touches : [event]);
|
|
e = (event.changedTouches && event.changedTouches[0]) || (event.originalEvent && event.originalEvent.changedTouches && event.originalEvent.changedTouches[0]) || touches[0].originalEvent || touches[0];
|
|
return {
|
|
"x": e.clientX,
|
|
"y": e.clientY
|
|
};
|
|
}, function(event) {
|
|
var e;
|
|
e = event;
|
|
return {
|
|
"x": e.clientX,
|
|
"y": e.clientY
|
|
};
|
|
}
|
|
];
|
|
|
|
getCoordinates = IsTouch ? getCoordinatesArray[0] : getCoordinatesArray[1];
|
|
|
|
function Slip(ele, direction) {
|
|
this.ele = ele;
|
|
this.direction = direction;
|
|
this._isPressed = false;
|
|
this.onStart = this.onMove = this.onEnd = noop;
|
|
this.coord = this.eventCoords = this.cacheCoords = this.finger = this.absFinger = NULL;
|
|
this.orient = [];
|
|
this.isSlider = false;
|
|
this.isWebapp = false;
|
|
this.duration = "400";
|
|
}
|
|
|
|
Slip.prototype.start = function(fn) {
|
|
return (this.onStart = fn) && this;
|
|
};
|
|
|
|
Slip.prototype.move = function(fn) {
|
|
return (this.onMove = fn) && this;
|
|
};
|
|
|
|
Slip.prototype.end = function(fn) {
|
|
return (this.onEnd = fn) && this;
|
|
};
|
|
|
|
Slip.prototype.setCoord = function(userCoords) {
|
|
var attr, coords, ele;
|
|
coords = this.coord = {
|
|
"x": userCoords[X] || 0,
|
|
"y": userCoords[Y] || 0
|
|
};
|
|
ele = this.ele;
|
|
setTranslate(ele, coords[X], coords[Y]);
|
|
for (attr in coords) {
|
|
ele.setAttribute(attr, coords[attr]);
|
|
}
|
|
return this;
|
|
};
|
|
|
|
Slip.prototype.onTouchStart = function(event) {
|
|
var ret;
|
|
this._isPressed = true;
|
|
this.eventCoords = getCoordinates(event);
|
|
this.cacheCoords = this.coord;
|
|
this.finger = this.absFinger = NULL;
|
|
if (this.isSlider) {
|
|
this.onSliderStart(event);
|
|
}
|
|
return ret = this.onStart.apply(this, [event]);
|
|
};
|
|
|
|
Slip.prototype.onTouchMove = function(event) {
|
|
var absFinger, attr, direction, ele, eleMove, finger, moveCoords, oppDirection, orient, ret, _results;
|
|
event.preventDefault();
|
|
if (!this._isPressed) {
|
|
return false;
|
|
}
|
|
moveCoords = getCoordinates(event);
|
|
direction = this.direction;
|
|
finger = this.finger = {
|
|
x: moveCoords.x - this.eventCoords.x,
|
|
y: moveCoords.y - this.eventCoords.y
|
|
};
|
|
absFinger = this.absFinger = {
|
|
x: Math.abs(finger.x),
|
|
y: Math.abs(finger.y)
|
|
};
|
|
if (direction !== XY) {
|
|
oppDirection = direction === X ? Y : X;
|
|
if (absFinger[direction] < MIN_ALLOW_DISTANCE || absFinger[oppDirection] > MAX_OPP_ALLOW_DISTANCE) {
|
|
return false;
|
|
}
|
|
}
|
|
orient = [];
|
|
if (absFinger.x > MIN_ALLOW_DISTANCE) {
|
|
orient.push(finger.x < 0 ? LEFT : RIGHT);
|
|
}
|
|
if (absFinger.y > MIN_ALLOW_DISTANCE) {
|
|
orient.push(finger.y < 0 ? UP : DOWN);
|
|
}
|
|
this.orient = orient;
|
|
ret = this.onMove.apply(this, [event]);
|
|
if (ret === false) {
|
|
return false;
|
|
}
|
|
ele = this.ele;
|
|
eleMove = this.coord = {
|
|
"x": direction.indexOf(X) < 0 ? this.cacheCoords[X] : this.cacheCoords[X] - 0 + finger.x,
|
|
"y": direction.indexOf(Y) < 0 ? this.cacheCoords[Y] : this.cacheCoords[Y] - 0 + finger.y
|
|
};
|
|
setTranslate(ele, eleMove[X], eleMove[Y]);
|
|
_results = [];
|
|
for (attr in eleMove) {
|
|
_results.push(ele.setAttribute(attr, eleMove[attr]));
|
|
}
|
|
return _results;
|
|
};
|
|
|
|
Slip.prototype.onTouchEnd = function(event) {
|
|
var ele, trans;
|
|
this._isPressed = false;
|
|
ele = this.ele;
|
|
if (this.isSlider) {
|
|
this.onSliderEnd(event);
|
|
}
|
|
trans = getTranslate(this.ele);
|
|
if (trans) {
|
|
this.setCoord(trans);
|
|
}
|
|
return this.orient = [];
|
|
};
|
|
|
|
Slip.prototype.onSliderStart = function(event) {
|
|
return setTransition(this.ele, NULL);
|
|
};
|
|
|
|
Slip.prototype.onSliderEnd = function(event, data) {
|
|
var absFinger, duration, ele, isDown, isJump, isLeft, isOut, isRight, isUp, isVerticalWebapp, jumpPage, orient, page, pageNum, ret, trans;
|
|
if (data == null) {
|
|
data = {};
|
|
}
|
|
jumpPage = data.jumpPage;
|
|
isJump = jumpPage;
|
|
orient = this.orient.join("");
|
|
trans = 0;
|
|
isOut = false;
|
|
page = this.page;
|
|
pageNum = this.pageNum;
|
|
ele = this.ele;
|
|
duration = this.duration;
|
|
absFinger = this.absFinger;
|
|
isUp = orient.indexOf(UP) > -1;
|
|
isDown = orient.indexOf(DOWN) > -1;
|
|
isLeft = orient.indexOf(LEFT) > -1;
|
|
isRight = orient.indexOf(RIGHT) > -1;
|
|
isVerticalWebapp = this.direction === Y;
|
|
if (jumpPage !== UNDEFINED) {
|
|
page = jumpPage;
|
|
} else {
|
|
if (isVerticalWebapp) {
|
|
if (isUp) {
|
|
page++;
|
|
}
|
|
if (isDown) {
|
|
page--;
|
|
}
|
|
} else {
|
|
if (isLeft) {
|
|
page++;
|
|
}
|
|
if (isRight) {
|
|
page--;
|
|
}
|
|
}
|
|
}
|
|
if (page >= pageNum) {
|
|
page = pageNum - 1;
|
|
isOut = true;
|
|
}
|
|
if (page < 0) {
|
|
page = 0;
|
|
isOut = true;
|
|
}
|
|
if (isOut === true && !isJump) {
|
|
duration *= isVerticalWebapp ? absFinger[Y] / this.pageHeight : absFinger[X] / this.pageWidth;
|
|
}
|
|
setTransition(ele, "all " + duration + "ms ease-in");
|
|
if (isVerticalWebapp) {
|
|
trans = "-" + (page * this.pageHeight);
|
|
setTranslate(ele, 0, trans, 0);
|
|
} else {
|
|
trans = "-" + (page * this.pageWidth);
|
|
setTranslate(ele, trans, 0, 0);
|
|
}
|
|
this.page = page;
|
|
if (isJump) {
|
|
this.onTouchEnd.call(this, NULL);
|
|
}
|
|
ret = this.onEnd.apply(this, [event]);
|
|
return this;
|
|
};
|
|
|
|
Slip.prototype.init = function() {
|
|
var attr, direction, ele, initMove, onTouchEnd, onTouchMove, onTouchStart;
|
|
this.coord = {
|
|
"x": 0,
|
|
"y": 0
|
|
};
|
|
onTouchStart = this._onTouchStart = (function(_this) {
|
|
return function(event) {
|
|
return _this.onTouchStart(event);
|
|
};
|
|
})(this);
|
|
onTouchMove = this._onTouchMove = (function(_this) {
|
|
return function(event) {
|
|
return _this.onTouchMove(event);
|
|
};
|
|
})(this);
|
|
onTouchEnd = this._onTouchEnd = (function(_this) {
|
|
return function(event) {
|
|
return _this.onTouchEnd(event);
|
|
};
|
|
})(this);
|
|
ele = this.ele;
|
|
ele.addEventListener(START_EVENT, onTouchStart, false);
|
|
ele.addEventListener(MOVE_EVENT, onTouchMove, false);
|
|
ele.addEventListener(END_EVENT, onTouchEnd, false);
|
|
initMove = this.coord = {
|
|
"x": 0,
|
|
"y": 0
|
|
};
|
|
direction = this.direction;
|
|
setTranslate(ele, initMove[X], initMove[Y]);
|
|
for (attr in initMove) {
|
|
ele.setAttribute(attr, initMove[attr]);
|
|
}
|
|
return this;
|
|
};
|
|
|
|
Slip.prototype.destroy = function() {
|
|
var ele;
|
|
ele = this.ele;
|
|
ele.removeEventListener(START_EVENT, this._onTouchStart, false);
|
|
ele.removeEventListener(MOVE_EVENT, this._onTouchMove, false);
|
|
ele.removeEventListener(END_EVENT, this._onTouchEnd, false);
|
|
return this;
|
|
};
|
|
|
|
Slip.prototype.slider = function(elPages) {
|
|
var elChild, elChilds, elPage, elPagesLen, ele, pageNum, _i, _j, _len, _len1;
|
|
ele = this.ele;
|
|
if (typeof elPages === "string") {
|
|
elPages = ele.querySelectorAll(elPages);
|
|
} else if (!elPages) {
|
|
elPages = [];
|
|
elChilds = ele.childNodes;
|
|
for (_i = 0, _len = elChilds.length; _i < _len; _i++) {
|
|
elChild = elChilds[_i];
|
|
if (elChild.nodeType === 1) {
|
|
elPages.push(elChild);
|
|
}
|
|
}
|
|
}
|
|
this.isSlider = true;
|
|
this.page = 0;
|
|
this.elPages = elPages;
|
|
elPagesLen = elPages.length;
|
|
pageNum = this.pageNum = elPagesLen ? elPagesLen : 0;
|
|
if (this.direction === X) {
|
|
for (_j = 0, _len1 = elPages.length; _j < _len1; _j++) {
|
|
elPage = elPages[_j];
|
|
elPage.style.cssFloat = LEFT;
|
|
}
|
|
}
|
|
return this;
|
|
};
|
|
|
|
Slip.prototype.webapp = function(elPages) {
|
|
var ele, pageNum;
|
|
this.isWebapp = true;
|
|
this.slider(elPages).fullscreen();
|
|
elPages = this.elPages;
|
|
ele = this.ele;
|
|
pageNum = this.pageNum;
|
|
ele.style.height = "" + (WINDOW_HEIGHT * pageNum) + "px";
|
|
this.height(WINDOW_HEIGHT);
|
|
if (this.direction === X) {
|
|
this.width(WINDOW_WIDTH);
|
|
}
|
|
return this;
|
|
};
|
|
|
|
Slip.prototype.height = function(num) {
|
|
var elPage, elPages, ele, pageNum, _i, _len;
|
|
ele = this.ele;
|
|
elPages = this.elPages;
|
|
pageNum = this.pageNum;
|
|
num = String(num).replace("px", "");
|
|
if (num === "100%") {
|
|
num = WINDOW_HEIGHT;
|
|
}
|
|
this.pageHeight = num;
|
|
if (this.direction === X) {
|
|
ele.style.height = "" + num + "px";
|
|
}
|
|
for (_i = 0, _len = elPages.length; _i < _len; _i++) {
|
|
elPage = elPages[_i];
|
|
elPage.style.height = "" + num + "px";
|
|
}
|
|
return this;
|
|
};
|
|
|
|
Slip.prototype.width = function(num) {
|
|
var elPage, elPages, ele, pageNum, _i, _len;
|
|
ele = this.ele;
|
|
elPages = this.elPages;
|
|
pageNum = this.pageNum;
|
|
num = String(num).replace("px", "");
|
|
if (num === "100%") {
|
|
num = WINDOW_WIDTH;
|
|
}
|
|
this.pageWidth = num;
|
|
if (this.direction === X) {
|
|
ele.style.width = "" + (num * pageNum) + "px";
|
|
}
|
|
for (_i = 0, _len = elPages.length; _i < _len; _i++) {
|
|
elPage = elPages[_i];
|
|
elPage.style.width = "" + num + "px";
|
|
}
|
|
return this;
|
|
};
|
|
|
|
Slip.prototype.fullscreen = function() {
|
|
var child, ele, parent;
|
|
ele = this.ele;
|
|
child = ele;
|
|
while (parent = child.parentNode) {
|
|
if (parent.nodeType === 1) {
|
|
parent.style.height = "100%";
|
|
parent.style.overflow = "hidden";
|
|
}
|
|
child = parent;
|
|
}
|
|
return this;
|
|
};
|
|
|
|
Slip.prototype.time = function(duration) {
|
|
this.duration = String(duration).replace("ms", "");
|
|
return this;
|
|
};
|
|
|
|
Slip.prototype.jump = function(page) {
|
|
this.onSliderEnd(NULL, {
|
|
jumpPage: page
|
|
});
|
|
return this;
|
|
};
|
|
|
|
return Slip;
|
|
|
|
})();
|
|
entry = function(ele, direction) {
|
|
var instance;
|
|
instance = new Slip(ele, direction || X);
|
|
return instance.init();
|
|
};
|
|
if (typeof define === "function") {
|
|
return define("binnng/slip.js", function(require, exports, module) {
|
|
return entry;
|
|
});
|
|
} else {
|
|
return WIN["Slip"] = entry;
|
|
}
|
|
})(window, document);
|