Permalink
Browse files

Build scrollability.js back into a single file; tweak scrollbar opaci…

…ty timing
  • Loading branch information...
1 parent 5ef64ef commit f5a9395e5ed8ff21c2722531601b34d48de63366 Joshua Gross committed Oct 14, 2011
Showing with 79 additions and 35 deletions.
  1. +78 −34 scrollability.js
  2. +1 −1 static/examples/tableview.html
View
@@ -1,6 +1,31 @@
+// Global variable for exported functions
+var scrollability = {};
+
+(function(require, exports) {
+
/* See LICENSE for terms of usage */
-"style scrollability/scrollbar.css"
+// Add the scrollbar styles to a new style tag
+var style = document.createElement('style');
+style.innerHTML =
+ '.scrollable { -webkit-transform: translate3d(0,0,0); }'
+ + '.scrollability-scrollbar {'
+ + 'position: absolute;'
+ + 'top: 0;'
+ + 'right: 2px;'
+ + 'width: 7px;'
+ + 'height: 1px;'
+ + 'z-index: 2147483647;'
+ + 'opacity: 0;'
+ + '-webkit-transform-origin: top left;'
+ + '-webkit-transform: translate3d(0,0,0);'
+ + '-webkit-box-sizing: border-box;'
+ + '-webkit-border-image: url("") 6 2 6 2 / 3px 1px 3px 1px round round;'
+ /*
+ + 'background: url("") no-repeat;'
+ */
+ + '}';
+document.head.appendChild(style);
// var logs = [];
@@ -77,18 +102,19 @@ var directions = {
exports.directions = directions;
exports.flashIndicators = function() {
+ // This needs to be implemented without scrolling to 0, 0 for each indicator
// var scrollables = document.querySelectorAll('.scrollable.vertical');
// for (var i = 0; i < scrollables.length; ++i) {
// exports.scrollTo(scrollables[i], 0, 0, 20, true);
- // }
+ // }
}
function onLoad() {
var ss = document.createElement("style");
document.head.appendChild(ss);
globalStyleSheet = document.styleSheets[document.styleSheets.length-1];
- // exports.flashIndicators();
+ exports.flashIndicators();
}
require.ready(function() {
@@ -119,7 +145,7 @@ function onTouchStart(event) {
document.addEventListener(isTouch ? 'touchend' : 'mouseup', onTouchEnd, false);
// if (D) event.preventDefault();
-
+
function onTouchMove(event) {
event.preventDefault();
touchMoved = true;
@@ -162,15 +188,15 @@ function onTouchStart(event) {
function onTouchEnd(event) {
// Simulate a click event when releasing the finger
if (touched) {
- var evt = document.createEvent('MouseEvents');
+ var evt = document.createEvent('MouseEvents');
evt.initMouseEvent('click', true, true, window, 1);
- touched[0].dispatchEvent(evt);
+ touched[0].dispatchEvent(evt);
releaseTouched(touched);
}
document.removeEventListener(isTouch ? 'touchmove' : 'mousemove', onTouchMove, false);
document.removeEventListener(isTouch ? 'touchend' : 'mouseup', onTouchEnd, false);
-
+
touchAnimators.forEach(function(animator) {
animator.takeoff();
});
@@ -228,7 +254,7 @@ function wrapAnimator(animator, startX, startY, startTime) {
if (scrollbar) {
addTracker(scrollbar, trackScrollbar);
if (!scrollbar.parentNode) {
- node.parentNode.appendChild(scrollbar);
+ node.parentNode.appendChild(scrollbar);
}
}
@@ -242,13 +268,13 @@ function wrapAnimator(animator, startX, startY, startTime) {
update(position);
}
-
+
animator.reposition = update;
animator.track = track;
animator.takeoff = takeoff;
animator.terminate = terminate;
return animator;
-
+
function addTracker(node, callback) {
tracked.push({node: node, callback: callback, keyframes: []});
}
@@ -274,7 +300,7 @@ function wrapAnimator(animator, startX, startY, startTime) {
velocity = touch - lastTouch;
lastTouch = touch;
-
+
if (Math.abs(velocity) >= kStoppedThreshold) {
if (stopped) {
--stopped;
@@ -324,8 +350,10 @@ function wrapAnimator(animator, startX, startY, startTime) {
}
scrollPosition += kScrollbarMargin;
- return 'translate3d(0, ' + Math.round(scrollPosition) + 'px, 0) '
- + 'scaleY(' + Math.round(height) + ')';
+ return {webkitTransform: 'translate3d(0, ' + Math.round(scrollPosition) + 'px, 0) ',
+ height: Math.round(height) + 'px'
+ };
+ /*+ 'scale3d(1, ' + Math.round(height) + ', 1)';*/
}
}
@@ -360,7 +388,7 @@ function wrapAnimator(animator, startX, startY, startTime) {
if (node.cleanup) {
node.cleanup();
- }
+ }
globalStyleSheet.insertRule(timeline.css, 0);
@@ -387,7 +415,7 @@ function wrapAnimator(animator, startX, startY, startTime) {
}
node.addEventListener("webkitAnimationEnd", node.normalEnd, false);
-
+
play(node, timeline.name, timeline.time);
tracked.forEach(function(item) {
@@ -485,7 +513,7 @@ function wrapAnimator(animator, startX, startY, startTime) {
position += velocity;
}
- saveKeyframe(!continues);
+ saveKeyframe(!continues);
time += kAnimationStep;
}
@@ -544,7 +572,14 @@ function wrapAnimator(animator, startX, startY, startTime) {
node.scrollableOffset = offset;
tracked.forEach(function(item) {
- item.node.style.webkitTransform = item.callback(pos);
+ var cb = item.callback(pos);
+ if(typeof cb == 'string') {
+ item.node.style.webkitTransform = item.callback(pos);
+ } else {
+ for(var prop in cb) {
+ item.node.style[prop] = cb[prop];
+ }
+ }
});
}
@@ -553,20 +588,22 @@ function wrapAnimator(animator, startX, startY, startTime) {
if (showScrollbar) {
fadeIn(scrollbar);
} else {
- scrollbar.style.opacity = '0';
- scrollbar.style.webkitTransition = 'opacity 0.33s linear';
+ setTimeout(function() {
+ scrollbar.style.opacity = '0';
+ scrollbar.style.webkitTransition = 'opacity 0.225s linear';
+ }, 50);
}
}
- node.removeEventListener("webkitAnimationEnd", node.normalEnd, false);
+ node.removeEventListener("webkitAnimationEnd", node.normalEnd, false);
delete node.earlyEnd;
delete node.normalEnd;
-
+
if (!animator.mute) {
dispatch("scrollability-end", node);
}
-
+
}
function terminate() {
@@ -578,7 +615,7 @@ function wrapAnimator(animator, startX, startY, startTime) {
function getTouchAnimators(node, touchX, touchY, startTime) {
var animators = [];
-
+
// Get universally scrollable elements
var candidates = document.querySelectorAll('.scrollable.universal');
for (var j = 0; j < candidates.length; ++j) {
@@ -609,7 +646,7 @@ function findAnimators(element, animators, touchX, touchY, startTime) {
if (!exists) {
animator = wrapAnimator(animator, touchX, touchY, startTime);
if (animator) {
- animators.push(animator);
+ animators.push(animator);
}
}
}
@@ -622,7 +659,7 @@ function createAnimatorForElement(element, touchX, touchY, startTime) {
var classes = element.className.split(' ');
if (classes.indexOf("scrollable") == -1)
return;
-
+
for (var i = 0; i < classes.length; ++i) {
var name = classes[i];
if (directions[name]) {
@@ -640,15 +677,16 @@ function generateCSSKeyframes(animator, keyframes, name, time, offset) {
keyframes.forEach(function(keyframe) {
var percent = (keyframe.time / time) * 100;
var frame = Math.floor(percent) + '% {'
- + '-webkit-transform: ' + (keyframe.css || animator.update(keyframe.position+offset)) + ';'
+ + '-webkit-transform: ' + (keyframe.css ? keyframe.css['webkitTransform'] : animator.update(keyframe.position+offset)) + ';'
+ + (keyframe.css && 'height' in keyframe.css ? 'height: ' + keyframe.css['height'] + ';' : '')
+ '}';
// D&&D(frame);
lines.push(frame);
});
lines.push('}');
- return lines.join('\n');
+ return lines.join('\n');
}
function setTouched(target) {
@@ -702,9 +740,9 @@ function createXDirection(node) {
viewport: parent.offsetWidth,
bounce: parent.offsetWidth * kBounceLimit,
constrained: true,
-
+
filter: function(x, y) {
- return x;
+ return x;
},
disable: function (x, y, startX, startY) {
@@ -743,23 +781,23 @@ function createYDirection(node) {
viewport: parent.offsetHeight,
bounce: parent.offsetHeight * kBounceLimit,
constrained: true,
-
+
filter: function(x, y) {
return y;
},
-
+
disable: function(x, y, startX, startY) {
var dx = Math.abs(x - startX);
var dy = Math.abs(y - startY);
if (dx > dy && dx > kLockThreshold) {
return true;
}
},
-
+
update: function(position) {
return 'translate3d(0, ' + Math.round(position) + 'px, 0)';
}
- };
+ };
}
function play(node, name, time) {
@@ -774,6 +812,7 @@ function fadeIn(node) {
node.style.opacity = '1';
}
+// "scrollability-" event dispatcher
function dispatch(name, target, props) {
var e = document.createEvent("Events");
e.initEvent(name, false, true);
@@ -785,4 +824,9 @@ function dispatch(name, target, props) {
}
return target.dispatchEvent(e);
-}
+}
+
+})(
+ /* require */ {ready: function(fn) { fn(); }},
+ /* exports */ scrollability
+);
@@ -79,7 +79,7 @@
</style>
-<script type="text/javascript" src="/scrollability.min.js"></script>
+<script type="text/javascript" src="../../scrollability.js"></script>
<script language="javascript">

0 comments on commit f5a9395

Please sign in to comment.