aboutsummaryrefslogtreecommitdiff
path: root/plugin/notes/notes.js
diff options
context:
space:
mode:
authorMichael Kühnel <mail@michael-kuehnel.de>2012-10-24 14:33:16 +0200
committerMichael Kühnel <mail@michael-kuehnel.de>2012-10-24 14:33:16 +0200
commit296242f8d3d5f5513d5278e72941ef868c3cb4e5 (patch)
treed43c6b42e02b0f27c2b124c88bec8ddc6e927543 /plugin/notes/notes.js
parent76a7bd83faa2ecd9c5442a6037e86084a574ab00 (diff)
downloadperl-software-in-gnu-guix-296242f8d3d5f5513d5278e72941ef868c3cb4e5.tar
perl-software-in-gnu-guix-296242f8d3d5f5513d5278e72941ef868c3cb4e5.tar.gz
Make the fragments visible in speaker notes
Diffstat (limited to 'plugin/notes/notes.js')
-rw-r--r--plugin/notes/notes.js67
1 files changed, 50 insertions, 17 deletions
diff --git a/plugin/notes/notes.js b/plugin/notes/notes.js
index 729dad3..45d13a4 100644
--- a/plugin/notes/notes.js
+++ b/plugin/notes/notes.js
@@ -7,15 +7,36 @@ var RevealNotes = (function() {
function openNotes() {
var notesPopup = window.open( 'plugin/notes/notes.html', 'reveal.js - Notes', 'width=1120,height=850' );
- Reveal.addEventListener( 'slidechanged', post );
+ // Fires when slide is changed
+ Reveal.addEventListener( 'slidechanged', function( event ) {
+ post('slidechanged');
+ } );
+
+ // Fires when a fragment is shown
+ Reveal.addEventListener( 'fragmentshown', function( event ) {
+ post('fragmentshown');
+ } );
+
+ // Fires when a fragment is hidden
+ Reveal.addEventListener( 'fragmenthidden', function( event ) {
+ post('fragmenthidden');
+ } );
- // Posts the current slide data to the notes window
- function post() {
+ /**
+ * @description Posts the current slide data to the notes window
+ *
+ * @param {string} eventType Expecting 'slidechanged', 'fragmentshown' or 'fragmenthidden'
+ * set in the events above to define the needed slideDate.
+ */
+ function post(eventType) {
+ console.log(eventType);
var slideElement = Reveal.getCurrentSlide(),
indexh = Reveal.getIndices().h,
indexv = Reveal.getIndices().v,
+ notes = slideElement.querySelector( 'aside.notes' ),
nextindexh,
- nextindexv;
+ nextindexv,
+ slideData;
if( slideElement.nextElementSibling && slideElement.parentNode.nodeName == 'SECTION' ) {
nextindexh = indexh;
@@ -25,16 +46,26 @@ var RevealNotes = (function() {
nextindexv = 0;
}
- var notes = slideElement.querySelector( 'aside.notes' );
-
- var slideData = {
- notes : notes ? notes.innerHTML : '',
- indexh : indexh,
- indexv : indexv,
- nextindexh : nextindexh,
- nextindexv : nextindexv,
- markdown : notes ? typeof notes.getAttribute( 'data-markdown' ) === 'string' : false
- };
+ if (eventType === 'slidechanged') {
+ slideData = {
+ notes : notes ? notes.innerHTML : '',
+ indexh : indexh,
+ indexv : indexv,
+ nextindexh : nextindexh,
+ nextindexv : nextindexv,
+ markdown : notes ? typeof notes.getAttribute( 'data-markdown' ) === 'string' : false
+ };
+ }
+ else if (eventType === 'fragmentshown') {
+ slideData = {
+ fragment : 'next'
+ };
+ }
+ else if (eventType === 'fragmenthidden') {
+ slideData = {
+ fragment : 'prev'
+ };
+ }
notesPopup.postMessage( JSON.stringify( slideData ), '*' );
}
@@ -50,7 +81,9 @@ var RevealNotes = (function() {
} );
// Navigate to the current slide when the notes are loaded
- notesPopup.addEventListener( 'load', post, false );
+ notesPopup.addEventListener( 'load', function( event ) {
+ post('slidechanged');
+ }, false );
}
// If the there's a 'notes' query set, open directly
@@ -70,5 +103,5 @@ var RevealNotes = (function() {
}
}, false );
- return { open: openNotes }
-})(); \ No newline at end of file
+ return { open: openNotes };
+})();