Code clean up, and better comments

pull/21833/head
wmwragg 2016-08-30 10:45:17 +01:00
parent 2b1ed707c4
commit 83c4fd4b2f
1 changed files with 8 additions and 6 deletions

View File

@ -318,6 +318,8 @@ module.exports = React.createClass({
} }
}, },
// Doing the stckiy headers as raw DOM, for speed, as it gets very stuttery if done
// properly through React
_initAndPositionStickyHeaders: function(initialise, scrollToPosition) { _initAndPositionStickyHeaders: function(initialise, scrollToPosition) {
var scrollArea = this._getScrollNode(); var scrollArea = this._getScrollNode();
// Use the offset of the top of the scroll area from the window // Use the offset of the top of the scroll area from the window
@ -328,16 +330,16 @@ module.exports = React.createClass({
var scrollAreaHeight = ReactDOM.findDOMNode(this).getBoundingClientRect().height; var scrollAreaHeight = ReactDOM.findDOMNode(this).getBoundingClientRect().height;
if (initialise) { if (initialise) {
// Get a collection of sticky header containers // Get a collection of sticky header containers references
var stickies = document.getElementsByClassName("mx_RoomSubList_labelContainer"); this.stickies = document.getElementsByClassName("mx_RoomSubList_labelContainer");
// Make sure there is sufficient space to do sticky headers // Make sure there is sufficient space to do sticky headers
this.scrollAreaSufficient = (120 + (stickies[0].getBoundingClientRect().height * stickies.length)) < scrollAreaHeight; this.scrollAreaSufficient = (120 + (this.stickies[0].getBoundingClientRect().height * this.stickies.length)) < scrollAreaHeight;
// Initialise the sticky headers // Initialise the sticky headers
if (typeof stickies === "object" && stickies.length > 0) { if (typeof this.stickies === "object" && this.stickies.length > 0) {
// Initialise the sticky headers // Initialise the sticky headers
this.stickyWrappers = Array.prototype.map.call(stickies, function(sticky, i) { Array.prototype.forEach.call(this.stickies, function(sticky, i) {
// Save the positions of all the stickies within scroll area. // Save the positions of all the stickies within scroll area.
// These positions are relative to the LHS Panel top // These positions are relative to the LHS Panel top
sticky.dataset.originalPosition = sticky.offsetTop - scrollArea.offsetTop; sticky.dataset.originalPosition = sticky.offsetTop - scrollArea.offsetTop;
@ -360,7 +362,7 @@ module.exports = React.createClass({
scrollArea.scrollTop = scrollToPosition; scrollArea.scrollTop = scrollToPosition;
} }
// Stick headers to top and bottom, or free them // Stick headers to top and bottom, or free them
Array.prototype.forEach.call(this.stickyWrappers, function(sticky, i, stickyWrappers) { Array.prototype.forEach.call(this.stickies, function(sticky, i, stickyWrappers) {
var stickyPosition = sticky.dataset.originalPosition; var stickyPosition = sticky.dataset.originalPosition;
var stickyHeight = sticky.dataset.originalHeight; var stickyHeight = sticky.dataset.originalHeight;
var stickyHeader = sticky.childNodes[0]; var stickyHeader = sticky.childNodes[0];