diff options
Diffstat (limited to 'js/reveal.js')
-rw-r--r-- | js/reveal.js | 55 |
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'; - - } ); - } } |