mirror of
https://github.com/moodle/moodle.git
synced 2025-01-19 06:18:28 +01:00
MDL-48288 gradebook: fix floating footer exception when averages disabled
The code we use to update styles on floating elements did not account for situations where those floating elements don't exist. This was discovered when a test site didn't have column averages enabled, resulting in no floating footer element being created, so when _handleScrollEvent was fired the first time, a null reference exception was thrown trying to apply styles to a non-existent element.
This commit is contained in:
parent
ca0e301c7b
commit
a71d9d28b7
@ -173,7 +173,8 @@ Y.namespace('M.gradereport_grader').init = function(config) {
|
||||
var HEIGHT = 'height',
|
||||
WIDTH = 'width',
|
||||
OFFSETWIDTH = 'offsetWidth',
|
||||
OFFSETHEIGHT = 'offsetHeight';
|
||||
OFFSETHEIGHT = 'offsetHeight',
|
||||
LOGNS = 'moodle-core-grade-report-grader';
|
||||
|
||||
CSS.FLOATING = 'floating';
|
||||
|
||||
@ -980,44 +981,56 @@ FloatingHeaders.prototype = {
|
||||
floatingHeaderStyles[SELECTORS.FOOTERTITLE] = floatingFooterTitleStyles;
|
||||
}
|
||||
|
||||
// Apply the styles.
|
||||
// Apply the styles and mark elements as floating, or not.
|
||||
if (this.gradeItemHeadingContainer) {
|
||||
this.gradeItemHeadingContainer.setStyles(gradeItemHeadingContainerStyles);
|
||||
this.userColumnHeader.setStyles(userColumnHeaderStyles);
|
||||
this.userColumn.setStyles(userColumnStyles);
|
||||
this.footerRow.setStyles(footerStyles);
|
||||
|
||||
// And apply the styles to the generic left headers.
|
||||
Y.Object.each(floatingHeaderStyles, function(styles, key) {
|
||||
this.floatingHeaderRow[key].setStyles(styles);
|
||||
}, this);
|
||||
|
||||
// Mark the elements as floating, or not.
|
||||
if (headerFloats) {
|
||||
this.gradeItemHeadingContainer.addClass(CSS.FLOATING);
|
||||
} else {
|
||||
this.gradeItemHeadingContainer.removeClass(CSS.FLOATING);
|
||||
}
|
||||
|
||||
}
|
||||
if (this.userColumnHeader) {
|
||||
this.userColumnHeader.setStyles(userColumnHeaderStyles);
|
||||
if (userFloats) {
|
||||
this.userColumnHeader.addClass(CSS.FLOATING);
|
||||
this.userColumn.addClass(CSS.FLOATING);
|
||||
} else {
|
||||
this.userColumnHeader.removeClass(CSS.FLOATING);
|
||||
}
|
||||
}
|
||||
if (this.userColumn) {
|
||||
this.userColumn.setStyles(userColumnStyles);
|
||||
if (userFloats) {
|
||||
this.userColumn.addClass(CSS.FLOATING);
|
||||
} else {
|
||||
this.userColumn.removeClass(CSS.FLOATING);
|
||||
}
|
||||
|
||||
}
|
||||
if (this.footerRow) {
|
||||
this.footerRow.setStyles(footerStyles);
|
||||
if (footerFloats) {
|
||||
this.footerRow.addClass(CSS.FLOATING);
|
||||
} else {
|
||||
this.footerRow.removeClass(CSS.FLOATING);
|
||||
}
|
||||
}
|
||||
|
||||
// And apply the styles to the generic left headers.
|
||||
Y.Object.each(floatingHeaderStyles, function(styles, key) {
|
||||
if (this.floatingHeaderRow[key]) {
|
||||
this.floatingHeaderRow[key].setStyles(styles);
|
||||
}
|
||||
}, this);
|
||||
|
||||
|
||||
Y.Object.each(this.floatingHeaderRow, function(value, key) {
|
||||
if (this.floatingHeaderRow[key]) {
|
||||
if (leftTitleFloats) {
|
||||
this.floatingHeaderRow[key].addClass(CSS.FLOATING);
|
||||
} else {
|
||||
this.floatingHeaderRow[key].removeClass(CSS.FLOATING);
|
||||
}
|
||||
}
|
||||
}, this);
|
||||
|
||||
// The footer title has a more specific float setting.
|
||||
|
File diff suppressed because one or more lines are too long
@ -173,7 +173,8 @@ Y.namespace('M.gradereport_grader').init = function(config) {
|
||||
var HEIGHT = 'height',
|
||||
WIDTH = 'width',
|
||||
OFFSETWIDTH = 'offsetWidth',
|
||||
OFFSETHEIGHT = 'offsetHeight';
|
||||
OFFSETHEIGHT = 'offsetHeight',
|
||||
LOGNS = 'moodle-core-grade-report-grader';
|
||||
|
||||
CSS.FLOATING = 'floating';
|
||||
|
||||
@ -979,44 +980,56 @@ FloatingHeaders.prototype = {
|
||||
floatingHeaderStyles[SELECTORS.FOOTERTITLE] = floatingFooterTitleStyles;
|
||||
}
|
||||
|
||||
// Apply the styles.
|
||||
// Apply the styles and mark elements as floating, or not.
|
||||
if (this.gradeItemHeadingContainer) {
|
||||
this.gradeItemHeadingContainer.setStyles(gradeItemHeadingContainerStyles);
|
||||
this.userColumnHeader.setStyles(userColumnHeaderStyles);
|
||||
this.userColumn.setStyles(userColumnStyles);
|
||||
this.footerRow.setStyles(footerStyles);
|
||||
|
||||
// And apply the styles to the generic left headers.
|
||||
Y.Object.each(floatingHeaderStyles, function(styles, key) {
|
||||
this.floatingHeaderRow[key].setStyles(styles);
|
||||
}, this);
|
||||
|
||||
// Mark the elements as floating, or not.
|
||||
if (headerFloats) {
|
||||
this.gradeItemHeadingContainer.addClass(CSS.FLOATING);
|
||||
} else {
|
||||
this.gradeItemHeadingContainer.removeClass(CSS.FLOATING);
|
||||
}
|
||||
|
||||
}
|
||||
if (this.userColumnHeader) {
|
||||
this.userColumnHeader.setStyles(userColumnHeaderStyles);
|
||||
if (userFloats) {
|
||||
this.userColumnHeader.addClass(CSS.FLOATING);
|
||||
this.userColumn.addClass(CSS.FLOATING);
|
||||
} else {
|
||||
this.userColumnHeader.removeClass(CSS.FLOATING);
|
||||
}
|
||||
}
|
||||
if (this.userColumn) {
|
||||
this.userColumn.setStyles(userColumnStyles);
|
||||
if (userFloats) {
|
||||
this.userColumn.addClass(CSS.FLOATING);
|
||||
} else {
|
||||
this.userColumn.removeClass(CSS.FLOATING);
|
||||
}
|
||||
|
||||
}
|
||||
if (this.footerRow) {
|
||||
this.footerRow.setStyles(footerStyles);
|
||||
if (footerFloats) {
|
||||
this.footerRow.addClass(CSS.FLOATING);
|
||||
} else {
|
||||
this.footerRow.removeClass(CSS.FLOATING);
|
||||
}
|
||||
}
|
||||
|
||||
// And apply the styles to the generic left headers.
|
||||
Y.Object.each(floatingHeaderStyles, function(styles, key) {
|
||||
if (this.floatingHeaderRow[key]) {
|
||||
this.floatingHeaderRow[key].setStyles(styles);
|
||||
}
|
||||
}, this);
|
||||
|
||||
|
||||
Y.Object.each(this.floatingHeaderRow, function(value, key) {
|
||||
if (this.floatingHeaderRow[key]) {
|
||||
if (leftTitleFloats) {
|
||||
this.floatingHeaderRow[key].addClass(CSS.FLOATING);
|
||||
} else {
|
||||
this.floatingHeaderRow[key].removeClass(CSS.FLOATING);
|
||||
}
|
||||
}
|
||||
}, this);
|
||||
|
||||
// The footer title has a more specific float setting.
|
||||
|
@ -30,7 +30,8 @@
|
||||
var HEIGHT = 'height',
|
||||
WIDTH = 'width',
|
||||
OFFSETWIDTH = 'offsetWidth',
|
||||
OFFSETHEIGHT = 'offsetHeight';
|
||||
OFFSETHEIGHT = 'offsetHeight',
|
||||
LOGNS = 'moodle-core-grade-report-grader';
|
||||
|
||||
CSS.FLOATING = 'floating';
|
||||
|
||||
@ -837,44 +838,56 @@ FloatingHeaders.prototype = {
|
||||
floatingHeaderStyles[SELECTORS.FOOTERTITLE] = floatingFooterTitleStyles;
|
||||
}
|
||||
|
||||
// Apply the styles.
|
||||
// Apply the styles and mark elements as floating, or not.
|
||||
if (this.gradeItemHeadingContainer) {
|
||||
this.gradeItemHeadingContainer.setStyles(gradeItemHeadingContainerStyles);
|
||||
this.userColumnHeader.setStyles(userColumnHeaderStyles);
|
||||
this.userColumn.setStyles(userColumnStyles);
|
||||
this.footerRow.setStyles(footerStyles);
|
||||
|
||||
// And apply the styles to the generic left headers.
|
||||
Y.Object.each(floatingHeaderStyles, function(styles, key) {
|
||||
this.floatingHeaderRow[key].setStyles(styles);
|
||||
}, this);
|
||||
|
||||
// Mark the elements as floating, or not.
|
||||
if (headerFloats) {
|
||||
this.gradeItemHeadingContainer.addClass(CSS.FLOATING);
|
||||
} else {
|
||||
this.gradeItemHeadingContainer.removeClass(CSS.FLOATING);
|
||||
}
|
||||
|
||||
}
|
||||
if (this.userColumnHeader) {
|
||||
this.userColumnHeader.setStyles(userColumnHeaderStyles);
|
||||
if (userFloats) {
|
||||
this.userColumnHeader.addClass(CSS.FLOATING);
|
||||
this.userColumn.addClass(CSS.FLOATING);
|
||||
} else {
|
||||
this.userColumnHeader.removeClass(CSS.FLOATING);
|
||||
}
|
||||
}
|
||||
if (this.userColumn) {
|
||||
this.userColumn.setStyles(userColumnStyles);
|
||||
if (userFloats) {
|
||||
this.userColumn.addClass(CSS.FLOATING);
|
||||
} else {
|
||||
this.userColumn.removeClass(CSS.FLOATING);
|
||||
}
|
||||
|
||||
}
|
||||
if (this.footerRow) {
|
||||
this.footerRow.setStyles(footerStyles);
|
||||
if (footerFloats) {
|
||||
this.footerRow.addClass(CSS.FLOATING);
|
||||
} else {
|
||||
this.footerRow.removeClass(CSS.FLOATING);
|
||||
}
|
||||
}
|
||||
|
||||
// And apply the styles to the generic left headers.
|
||||
Y.Object.each(floatingHeaderStyles, function(styles, key) {
|
||||
if (this.floatingHeaderRow[key]) {
|
||||
this.floatingHeaderRow[key].setStyles(styles);
|
||||
}
|
||||
}, this);
|
||||
|
||||
|
||||
Y.Object.each(this.floatingHeaderRow, function(value, key) {
|
||||
if (this.floatingHeaderRow[key]) {
|
||||
if (leftTitleFloats) {
|
||||
this.floatingHeaderRow[key].addClass(CSS.FLOATING);
|
||||
} else {
|
||||
this.floatingHeaderRow[key].removeClass(CSS.FLOATING);
|
||||
}
|
||||
}
|
||||
}, this);
|
||||
|
||||
// The footer title has a more specific float setting.
|
||||
|
Loading…
x
Reference in New Issue
Block a user