handled: false,
threshold: 80
};
+ /**
+ * Return a sorted fragments list, ordered by an increasing "fragment-pos" attribute.
+ *
+ * Fragments will be revealed in the order that they are returned by
+ * this function, so you can use "fragment-pos" attributes to control
+ * the order of fragment appearance.
+ *
+ * To maintain a sensible default fragment order, fragments are presumed
+ * to be passed in document order. This function adds a "fragment-pos"
+ * attribute to each node if such an attribute is not already present,
+ * and sets that attribute to an integer value which is the position of
+ * the fragment within the fragments list.
+ *
+ */
+ function sort_fragments( fragments ) {
+ var a = toArray(fragments)
+ a.forEach( function (el, idx) {
+ if (!el.hasAttribute('fragment-pos')) {
+ el.setAttribute('fragment-pos', idx) }})
+ a.sort(function(l, r) {
+ return l.getAttribute( 'fragment-pos' )
+ - r.getAttribute( 'fragment-pos') })
+ return a
+ }
/**
* Starts up the presentation if the client is capable.
// Show fragment, if specified
if( typeof f !== 'undefined' ) {
var fragments = currentSlide.querySelectorAll( '.fragment' );
+ fragments = sort_fragments(fragments)
toArray( fragments ).forEach( function( fragment, indexf ) {
if( indexf < f ) {
// Vertical slides:
if( document.querySelector( VERTICAL_SLIDES_SELECTOR + '.present' ) ) {
var verticalFragments = document.querySelectorAll( VERTICAL_SLIDES_SELECTOR + '.present .fragment:not(.visible)' );
+ verticalFragments = sort_fragments(verticalFragments)
if( verticalFragments.length ) {
verticalFragments[0].classList.add( 'visible' );
// Horizontal slides:
else {
var horizontalFragments = document.querySelectorAll( HORIZONTAL_SLIDES_SELECTOR + '.present .fragment:not(.visible)' );
+ horizontalFragments = sort_fragments(horizontalFragments)
if( horizontalFragments.length ) {
horizontalFragments[0].classList.add( 'visible' );
// Vertical slides:
if( document.querySelector( VERTICAL_SLIDES_SELECTOR + '.present' ) ) {
var verticalFragments = document.querySelectorAll( VERTICAL_SLIDES_SELECTOR + '.present .fragment.visible' );
+ verticalFragments = sort_fragments(verticalFragments)
if( verticalFragments.length ) {
verticalFragments[ verticalFragments.length - 1 ].classList.remove( 'visible' );
// Horizontal slides:
else {
var horizontalFragments = document.querySelectorAll( HORIZONTAL_SLIDES_SELECTOR + '.present .fragment.visible' );
+ horizontalFragments = sort_fragments(horizontalFragments)
if( horizontalFragments.length ) {
horizontalFragments[ horizontalFragments.length - 1 ].classList.remove( 'visible' );
}
};
-})();
\ No newline at end of file
+})();