aboutsummaryrefslogtreecommitdiffhomepage
path: root/js/reveal.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/reveal.js')
-rw-r--r--js/reveal.js55
1 files changed, 24 insertions, 31 deletions
diff --git a/js/reveal.js b/js/reveal.js
index acd5623..53428aa 100644
--- a/js/reveal.js
+++ b/js/reveal.js
@@ -722,43 +722,29 @@ var Reveal = (function(){
}
- function getComputedCSSProperty( element, prop ) {
-
- if( window.getComputedStyle ) {
- return window.getComputedStyle( element )[ prop ];
- }
- else {
- return element.currentStyle ? element.currentStyle( prop ) : element.style[ prop ];
- }
-
- }
-
/**
- * Returns the remaining height within the parent element
- * of the target after taking out the height of all
+ * Returns the remaining height within the parent of the
+ * target element after subtracting the height of all
* siblings.
*
* remaining height = [parent height] - [ siblings height]
*/
- function getRemainingHeight( element ) {
+ function getRemainingHeight( element, height ) {
- var height = 0;
+ height = height || 0;
if( element ) {
var parent = element.parentNode;
var siblings = parent.childNodes;
- height = config.height;
-
- // Remove the height of each sibling
+ // Subtract the height of each sibling
toArray( siblings ).forEach( function( sibling ) {
if( typeof sibling.offsetHeight === 'number' && sibling !== element ) {
- var marginTop = parseInt( getComputedCSSProperty( sibling, 'margin-top' ), 10 );
- var marginBottom = parseInt( getComputedCSSProperty( sibling, 'margin-bottom' ), 10 );
-
- console.log( marginTop, marginBottom );
+ var styles = window.getComputedStyle( sibling ),
+ marginTop = parseInt( styles[ 'margin-top' ], 10 ),
+ marginBottom = parseInt( styles[ 'margin-bottom' ], 10 );
height -= sibling.offsetHeight + marginTop + marginBottom;
@@ -766,6 +752,12 @@ var Reveal = (function(){
} );
+ var elementStyles = window.getComputedStyle( element );
+
+ // Subtract the margins of the target element
+ height -= parseInt( elementStyles[ 'margin-top' ], 10 ) +
+ parseInt( elementStyles[ 'margin-bottom' ], 10 );
+
}
return height;
@@ -1006,7 +998,8 @@ var Reveal = (function(){
// Dimensions of the content
var slideWidth = config.width,
- slideHeight = config.height;
+ slideHeight = config.height,
+ slidePadding = 20; // TODO Dig this out of DOM
// Slide width may be a percentage of available width
if( typeof slideWidth === 'string' && /%$/.test( slideWidth ) ) {
@@ -1021,6 +1014,13 @@ var Reveal = (function(){
dom.slides.style.width = slideWidth + 'px';
dom.slides.style.height = slideHeight + 'px';
+ // Handle sizing of elements with the 'remaining-height' class
+ toArray( dom.slides.querySelectorAll( 'section > .remaining-height' ) ).forEach( function( element ) {
+
+ element.style.height = getRemainingHeight( element, ( slideHeight - ( slidePadding * 2 ) ) ) + 'px';
+
+ } );
+
// Determine scale of content to fit within available space
scale = Math.min( availableWidth / slideWidth, availableHeight / slideHeight );
@@ -1056,7 +1056,7 @@ var Reveal = (function(){
slide.style.top = 0;
}
else {
- slide.style.top = Math.max( - ( getAbsoluteHeight( slide ) / 2 ) - 20, -slideHeight / 2 ) + 'px';
+ slide.style.top = Math.max( - ( getAbsoluteHeight( slide ) / 2 ) - slidePadding, -slideHeight / 2 ) + 'px';
}
}
else {
@@ -1067,13 +1067,6 @@ var Reveal = (function(){
updateProgress();
- // Handle sizing of elements with the 'remaining-height' class
- toArray( dom.slides.querySelectorAll( 'section > .remaining-height' ) ).forEach( function( element ) {
-
- element.style.height = getRemainingHeight( element ) + 'px';
-
- } );
-
}
}