|
|
|
@ -960,11 +960,6 @@ var makeMenu = function() {
|
|
|
|
|
document.querySelector('.paneHead').clientHeight + 'px'
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
// Make the header scroll with the window.
|
|
|
|
|
window.onscroll = function () {
|
|
|
|
|
document.querySelector('.paneHead').style.left = "-" + window.scrollX + "px";
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
startMatrixUpdate();
|
|
|
|
|
makeMatrixGroup0(groupStats[0]);
|
|
|
|
|
makeMatrixGroup1(groupStats[1]);
|
|
|
|
@ -1340,6 +1335,41 @@ var matrixSnapshotPoller = (function() {
|
|
|
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
|
|
|
|
|
|
// https://github.com/gorhill/uMatrix/pull/441
|
|
|
|
|
// Make the header scroll horizontally with the document.
|
|
|
|
|
|
|
|
|
|
// Ref.: resource-considerate scroll handler:
|
|
|
|
|
// https://developer.mozilla.org/en-US/docs/Web/Events/scroll#Example
|
|
|
|
|
// Won't cause DOM changes from within scroll handler.
|
|
|
|
|
|
|
|
|
|
var lastScrollX = 0;
|
|
|
|
|
var onScrollThrottledFired = false;
|
|
|
|
|
|
|
|
|
|
var onScrollThrottled = function() {
|
|
|
|
|
lastScrollX = window.scrollX;
|
|
|
|
|
var style = document.querySelector('.paneHead').style;
|
|
|
|
|
if ( lastScrollX === 0 ) {
|
|
|
|
|
style.removeProperty('left');
|
|
|
|
|
} else {
|
|
|
|
|
style.setProperty('left', '-' + lastScrollX + 'px');
|
|
|
|
|
}
|
|
|
|
|
onScrollThrottledFired = false;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
var onScroll = function() {
|
|
|
|
|
if ( onScrollThrottledFired || window.scrollX === lastScrollX ) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
onScrollThrottledFired = true;
|
|
|
|
|
self.requestAnimationFrame(onScrollThrottled);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
if ( typeof self.requestAnimationFrame === 'function' ) {
|
|
|
|
|
document.addEventListener('scroll', onScroll);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
|
|
|
|
|
|
// Below is UI stuff which is not key to make the menu, so this can
|
|
|
|
|
// be done without having to wait for a tab to be bound to the menu.
|
|
|
|
|
|
|
|
|
|