0.bundle.js 84 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. (window["webpackJsonp"] = window["webpackJsonp"] || []).push([[0],{
  2. /***/ "./node_modules/reveal.js/lib/js/classList.js":
  3. /*!****************************************************!*\
  4. !*** ./node_modules/reveal.js/lib/js/classList.js ***!
  5. \****************************************************/
  6. /*! no static exports found */
  7. /***/ (function(module, exports) {
  8. eval("/*! @source http://purl.eligrey.com/github/classList.js/blob/master/classList.js*/\nif(typeof document!==\"undefined\"&&!(\"classList\" in document.createElement(\"a\"))){(function(j){var a=\"classList\",f=\"prototype\",m=(j.HTMLElement||j.Element)[f],b=Object,k=String[f].trim||function(){return this.replace(/^\\s+|\\s+$/g,\"\")},c=Array[f].indexOf||function(q){var p=0,o=this.length;for(;p<o;p++){if(p in this&&this[p]===q){return p}}return -1},n=function(o,p){this.name=o;this.code=DOMException[o];this.message=p},g=function(p,o){if(o===\"\"){throw new n(\"SYNTAX_ERR\",\"An invalid or illegal string was specified\")}if(/\\s/.test(o)){throw new n(\"INVALID_CHARACTER_ERR\",\"String contains an invalid character\")}return c.call(p,o)},d=function(s){var r=k.call(s.className),q=r?r.split(/\\s+/):[],p=0,o=q.length;for(;p<o;p++){this.push(q[p])}this._updateClassName=function(){s.className=this.toString()}},e=d[f]=[],i=function(){return new d(this)};n[f]=Error[f];e.item=function(o){return this[o]||null};e.contains=function(o){o+=\"\";return g(this,o)!==-1};e.add=function(o){o+=\"\";if(g(this,o)===-1){this.push(o);this._updateClassName()}};e.remove=function(p){p+=\"\";var o=g(this,p);if(o!==-1){this.splice(o,1);this._updateClassName()}};e.toggle=function(o){o+=\"\";if(g(this,o)===-1){this.add(o)}else{this.remove(o)}};e.toString=function(){return this.join(\" \")};if(b.defineProperty){var l={get:i,enumerable:true,configurable:true};try{b.defineProperty(m,a,l)}catch(h){if(h.number===-2146823252){l.enumerable=false;b.defineProperty(m,a,l)}}}else{if(b[f].__defineGetter__){m.__defineGetter__(a,i)}}}(self))};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9ub2RlX21vZHVsZXMvcmV2ZWFsLmpzL2xpYi9qcy9jbGFzc0xpc3QuanMuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9ub2RlX21vZHVsZXMvcmV2ZWFsLmpzL2xpYi9qcy9jbGFzc0xpc3QuanM/MWIzMSJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiEgQHNvdXJjZSBodHRwOi8vcHVybC5lbGlncmV5LmNvbS9naXRodWIvY2xhc3NMaXN0LmpzL2Jsb2IvbWFzdGVyL2NsYXNzTGlzdC5qcyovXG5pZih0eXBlb2YgZG9jdW1lbnQhPT1cInVuZGVmaW5lZFwiJiYhKFwiY2xhc3NMaXN0XCIgaW4gZG9jdW1lbnQuY3JlYXRlRWxlbWVudChcImFcIikpKXsoZnVuY3Rpb24oail7dmFyIGE9XCJjbGFzc0xpc3RcIixmPVwicHJvdG90eXBlXCIsbT0oai5IVE1MRWxlbWVudHx8ai5FbGVtZW50KVtmXSxiPU9iamVjdCxrPVN0cmluZ1tmXS50cmltfHxmdW5jdGlvbigpe3JldHVybiB0aGlzLnJlcGxhY2UoL15cXHMrfFxccyskL2csXCJcIil9LGM9QXJyYXlbZl0uaW5kZXhPZnx8ZnVuY3Rpb24ocSl7dmFyIHA9MCxvPXRoaXMubGVuZ3RoO2Zvcig7cDxvO3ArKyl7aWYocCBpbiB0aGlzJiZ0aGlzW3BdPT09cSl7cmV0dXJuIHB9fXJldHVybiAtMX0sbj1mdW5jdGlvbihvLHApe3RoaXMubmFtZT1vO3RoaXMuY29kZT1ET01FeGNlcHRpb25bb107dGhpcy5tZXNzYWdlPXB9LGc9ZnVuY3Rpb24ocCxvKXtpZihvPT09XCJcIil7dGhyb3cgbmV3IG4oXCJTWU5UQVhfRVJSXCIsXCJBbiBpbnZhbGlkIG9yIGlsbGVnYWwgc3RyaW5nIHdhcyBzcGVjaWZpZWRcIil9aWYoL1xccy8udGVzdChvKSl7dGhyb3cgbmV3IG4oXCJJTlZBTElEX0NIQVJBQ1RFUl9FUlJcIixcIlN0cmluZyBjb250YWlucyBhbiBpbnZhbGlkIGNoYXJhY3RlclwiKX1yZXR1cm4gYy5jYWxsKHAsbyl9LGQ9ZnVuY3Rpb24ocyl7dmFyIHI9ay5jYWxsKHMuY2xhc3NOYW1lKSxxPXI/ci5zcGxpdCgvXFxzKy8pOltdLHA9MCxvPXEubGVuZ3RoO2Zvcig7cDxvO3ArKyl7dGhpcy5wdXNoKHFbcF0pfXRoaXMuX3VwZGF0ZUNsYXNzTmFtZT1mdW5jdGlvbigpe3MuY2xhc3NOYW1lPXRoaXMudG9TdHJpbmcoKX19LGU9ZFtmXT1bXSxpPWZ1bmN0aW9uKCl7cmV0dXJuIG5ldyBkKHRoaXMpfTtuW2ZdPUVycm9yW2ZdO2UuaXRlbT1mdW5jdGlvbihvKXtyZXR1cm4gdGhpc1tvXXx8bnVsbH07ZS5jb250YWlucz1mdW5jdGlvbihvKXtvKz1cIlwiO3JldHVybiBnKHRoaXMsbykhPT0tMX07ZS5hZGQ9ZnVuY3Rpb24obyl7bys9XCJcIjtpZihnKHRoaXMsbyk9PT0tMSl7dGhpcy5wdXNoKG8pO3RoaXMuX3VwZGF0ZUNsYXNzTmFtZSgpfX07ZS5yZW1vdmU9ZnVuY3Rpb24ocCl7cCs9XCJcIjt2YXIgbz1nKHRoaXMscCk7aWYobyE9PS0xKXt0aGlzLnNwbGljZShvLDEpO3RoaXMuX3VwZGF0ZUNsYXNzTmFtZSgpfX07ZS50b2dnbGU9ZnVuY3Rpb24obyl7bys9XCJcIjtpZihnKHRoaXMsbyk9PT0tMSl7dGhpcy5hZGQobyl9ZWxzZXt0aGlzLnJlbW92ZShvKX19O2UudG9TdHJpbmc9ZnVuY3Rpb24oKXtyZXR1cm4gdGhpcy5qb2luKFwiIFwiKX07aWYoYi5kZWZpbmVQcm9wZXJ0eSl7dmFyIGw9e2dldDppLGVudW1lcmFibGU6dHJ1ZSxjb25maWd1cmFibGU6dHJ1ZX07dHJ5e2IuZGVmaW5lUHJvcGVydHkobSxhLGwpfWNhdGNoKGgpe2lmKGgubnVtYmVyPT09LTIxNDY4MjMyNTIpe2wuZW51bWVyYWJsZT1mYWxzZTtiLmRlZmluZVByb3BlcnR5KG0sYSxsKX19fWVsc2V7aWYoYltmXS5fX2RlZmluZUdldHRlcl9fKXttLl9fZGVmaW5lR2V0dGVyX18oYSxpKX19fShzZWxmKSl9OyJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./node_modules/reveal.js/lib/js/classList.js\n");
  9. /***/ }),
  10. /***/ "./node_modules/reveal.js/plugin/notes/notes.js":
  11. /*!******************************************************!*\
  12. !*** ./node_modules/reveal.js/plugin/notes/notes.js ***!
  13. \******************************************************/
  14. /*! no static exports found */
  15. /***/ (function(module, exports) {
  16. eval("/**\n * Handles opening of and synchronization with the reveal.js\n * notes window.\n *\n * Handshake process:\n * 1. This window posts 'connect' to notes window\n * - Includes URL of presentation to show\n * 2. Notes window responds with 'connected' when it is available\n * 3. This window proceeds to send the current presentation state\n * to the notes window\n */\nvar RevealNotes = (function() {\n\n\tfunction openNotes( notesFilePath ) {\n\n\t\tif( !notesFilePath ) {\n\t\t\tvar jsFileLocation = document.querySelector('script[src$=\"notes.js\"]').src; // this js file path\n\t\t\tjsFileLocation = jsFileLocation.replace(/notes\\.js(\\?.*)?$/, ''); // the js folder path\n\t\t\tnotesFilePath = jsFileLocation + 'notes.html';\n\t\t}\n\n\t\tvar notesPopup = window.open( notesFilePath, 'reveal.js - Notes', 'width=1100,height=700' );\n\n\t\t// Allow popup window access to Reveal API\n\t\tnotesPopup.Reveal = this.Reveal;\n\n\t\t/**\n\t\t * Connect to the notes window through a postmessage handshake.\n\t\t * Using postmessage enables us to work in situations where the\n\t\t * origins differ, such as a presentation being opened from the\n\t\t * file system.\n\t\t */\n\t\tfunction connect() {\n\t\t\t// Keep trying to connect until we get a 'connected' message back\n\t\t\tvar connectInterval = setInterval( function() {\n\t\t\t\tnotesPopup.postMessage( JSON.stringify( {\n\t\t\t\t\tnamespace: 'reveal-notes',\n\t\t\t\t\ttype: 'connect',\n\t\t\t\t\turl: window.location.protocol + '//' + window.location.host + window.location.pathname + window.location.search,\n\t\t\t\t\tstate: Reveal.getState()\n\t\t\t\t} ), '*' );\n\t\t\t}, 500 );\n\n\t\t\twindow.addEventListener( 'message', function( event ) {\n\t\t\t\tvar data = JSON.parse( event.data );\n\t\t\t\tif( data && data.namespace === 'reveal-notes' && data.type === 'connected' ) {\n\t\t\t\t\tclearInterval( connectInterval );\n\t\t\t\t\tonConnected();\n\t\t\t\t}\n\t\t\t} );\n\t\t}\n\n\t\t/**\n\t\t * Posts the current slide data to the notes window\n\t\t */\n\t\tfunction post( event ) {\n\n\t\t\tvar slideElement = Reveal.getCurrentSlide(),\n\t\t\t\tnotesElement = slideElement.querySelector( 'aside.notes' ),\n\t\t\t\tfragmentElement = slideElement.querySelector( '.current-fragment' );\n\n\t\t\tvar messageData = {\n\t\t\t\tnamespace: 'reveal-notes',\n\t\t\t\ttype: 'state',\n\t\t\t\tnotes: '',\n\t\t\t\tmarkdown: false,\n\t\t\t\twhitespace: 'normal',\n\t\t\t\tstate: Reveal.getState()\n\t\t\t};\n\n\t\t\t// Look for notes defined in a slide attribute\n\t\t\tif( slideElement.hasAttribute( 'data-notes' ) ) {\n\t\t\t\tmessageData.notes = slideElement.getAttribute( 'data-notes' );\n\t\t\t\tmessageData.whitespace = 'pre-wrap';\n\t\t\t}\n\n\t\t\t// Look for notes defined in a fragment\n\t\t\tif( fragmentElement ) {\n\t\t\t\tvar fragmentNotes = fragmentElement.querySelector( 'aside.notes' );\n\t\t\t\tif( fragmentNotes ) {\n\t\t\t\t\tnotesElement = fragmentNotes;\n\t\t\t\t}\n\t\t\t\telse if( fragmentElement.hasAttribute( 'data-notes' ) ) {\n\t\t\t\t\tmessageData.notes = fragmentElement.getAttribute( 'data-notes' );\n\t\t\t\t\tmessageData.whitespace = 'pre-wrap';\n\n\t\t\t\t\t// In case there are slide notes\n\t\t\t\t\tnotesElement = null;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Look for notes defined in an aside element\n\t\t\tif( notesElement ) {\n\t\t\t\tmessageData.notes = notesElement.innerHTML;\n\t\t\t\tmessageData.markdown = typeof notesElement.getAttribute( 'data-markdown' ) === 'string';\n\t\t\t}\n\n\t\t\tnotesPopup.postMessage( JSON.stringify( messageData ), '*' );\n\n\t\t}\n\n\t\t/**\n\t\t * Called once we have established a connection to the notes\n\t\t * window.\n\t\t */\n\t\tfunction onConnected() {\n\n\t\t\t// Monitor events that trigger a change in state\n\t\t\tReveal.addEventListener( 'slidechanged', post );\n\t\t\tReveal.addEventListener( 'fragmentshown', post );\n\t\t\tReveal.addEventListener( 'fragmenthidden', post );\n\t\t\tReveal.addEventListener( 'overviewhidden', post );\n\t\t\tReveal.addEventListener( 'overviewshown', post );\n\t\t\tReveal.addEventListener( 'paused', post );\n\t\t\tReveal.addEventListener( 'resumed', post );\n\n\t\t\t// Post the initial state\n\t\t\tpost();\n\n\t\t}\n\n\t\tconnect();\n\n\t}\n\n\tif( !/receiver/i.test( window.location.search ) ) {\n\n\t\t// If the there's a 'notes' query set, open directly\n\t\tif( window.location.search.match( /(\\?|\\&)notes/gi ) !== null ) {\n\t\t\topenNotes();\n\t\t}\n\n\t\t// Open the notes when the 's' key is hit\n\t\tdocument.addEventListener( 'keydown', function( event ) {\n\t\t\t// Disregard the event if the target is editable or a\n\t\t\t// modifier is present\n\t\t\tif ( document.querySelector( ':focus' ) !== null || event.shiftKey || event.altKey || event.ctrlKey || event.metaKey ) return;\n\n\t\t\t// Disregard the event if keyboard is disabled\n\t\t\tif ( Reveal.getConfig().keyboard === false ) return;\n\n\t\t\tif( event.keyCode === 83 ) {\n\t\t\t\tevent.preventDefault();\n\t\t\t\topenNotes();\n\t\t\t}\n\t\t}, false );\n\n\t\t// Show our keyboard shortcut in the reveal.js help overlay\n\t\tif( window.Reveal ) Reveal.registerKeyboardShortcut( 'S', 'Speaker notes view' );\n\n\t}\n\n\treturn { open: openNotes };\n\n})();\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./node_modules/reveal.js/plugin/notes/notes.js.js","sources":["webpack:///./node_modules/reveal.js/plugin/notes/notes.js?df0c"],"sourcesContent":["/**\n * Handles opening of and synchronization with the reveal.js\n * notes window.\n *\n * Handshake process:\n * 1. This window posts 'connect' to notes window\n *    - Includes URL of presentation to show\n * 2. Notes window responds with 'connected' when it is available\n * 3. This window proceeds to send the current presentation state\n *    to the notes window\n */\nvar RevealNotes = (function() {\n\n\tfunction openNotes( notesFilePath ) {\n\n\t\tif( !notesFilePath ) {\n\t\t\tvar jsFileLocation = document.querySelector('script[src$=\"notes.js\"]').src;  // this js file path\n\t\t\tjsFileLocation = jsFileLocation.replace(/notes\\.js(\\?.*)?$/, '');   // the js folder path\n\t\t\tnotesFilePath = jsFileLocation + 'notes.html';\n\t\t}\n\n\t\tvar notesPopup = window.open( notesFilePath, 'reveal.js - Notes', 'width=1100,height=700' );\n\n\t\t// Allow popup window access to Reveal API\n\t\tnotesPopup.Reveal = this.Reveal;\n\n\t\t/**\n\t\t * Connect to the notes window through a postmessage handshake.\n\t\t * Using postmessage enables us to work in situations where the\n\t\t * origins differ, such as a presentation being opened from the\n\t\t * file system.\n\t\t */\n\t\tfunction connect() {\n\t\t\t// Keep trying to connect until we get a 'connected' message back\n\t\t\tvar connectInterval = setInterval( function() {\n\t\t\t\tnotesPopup.postMessage( JSON.stringify( {\n\t\t\t\t\tnamespace: 'reveal-notes',\n\t\t\t\t\ttype: 'connect',\n\t\t\t\t\turl: window.location.protocol + '//' + window.location.host + window.location.pathname + window.location.search,\n\t\t\t\t\tstate: Reveal.getState()\n\t\t\t\t} ), '*' );\n\t\t\t}, 500 );\n\n\t\t\twindow.addEventListener( 'message', function( event ) {\n\t\t\t\tvar data = JSON.parse( event.data );\n\t\t\t\tif( data && data.namespace === 'reveal-notes' && data.type === 'connected' ) {\n\t\t\t\t\tclearInterval( connectInterval );\n\t\t\t\t\tonConnected();\n\t\t\t\t}\n\t\t\t} );\n\t\t}\n\n\t\t/**\n\t\t * Posts the current slide data to the notes window\n\t\t */\n\t\tfunction post( event ) {\n\n\t\t\tvar slideElement = Reveal.getCurrentSlide(),\n\t\t\t\tnotesElement = slideElement.querySelector( 'aside.notes' ),\n\t\t\t\tfragmentElement = slideElement.querySelector( '.current-fragment' );\n\n\t\t\tvar messageData = {\n\t\t\t\tnamespace: 'reveal-notes',\n\t\t\t\ttype: 'state',\n\t\t\t\tnotes: '',\n\t\t\t\tmarkdown: false,\n\t\t\t\twhitespace: 'normal',\n\t\t\t\tstate: Reveal.getState()\n\t\t\t};\n\n\t\t\t// Look for notes defined in a slide attribute\n\t\t\tif( slideElement.hasAttribute( 'data-notes' ) ) {\n\t\t\t\tmessageData.notes = slideElement.getAttribute( 'data-notes' );\n\t\t\t\tmessageData.whitespace = 'pre-wrap';\n\t\t\t}\n\n\t\t\t// Look for notes defined in a fragment\n\t\t\tif( fragmentElement ) {\n\t\t\t\tvar fragmentNotes = fragmentElement.querySelector( 'aside.notes' );\n\t\t\t\tif( fragmentNotes ) {\n\t\t\t\t\tnotesElement = fragmentNotes;\n\t\t\t\t}\n\t\t\t\telse if( fragmentElement.hasAttribute( 'data-notes' ) ) {\n\t\t\t\t\tmessageData.notes = fragmentElement.getAttribute( 'data-notes' );\n\t\t\t\t\tmessageData.whitespace = 'pre-wrap';\n\n\t\t\t\t\t// In case there are slide notes\n\t\t\t\t\tnotesElement = null;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Look for notes defined in an aside element\n\t\t\tif( notesElement ) {\n\t\t\t\tmessageData.notes = notesElement.innerHTML;\n\t\t\t\tmessageData.markdown = typeof notesElement.getAttribute( 'data-markdown' ) === 'string';\n\t\t\t}\n\n\t\t\tnotesPopup.postMessage( JSON.stringify( messageData ), '*' );\n\n\t\t}\n\n\t\t/**\n\t\t * Called once we have established a connection to the notes\n\t\t * window.\n\t\t */\n\t\tfunction onConnected() {\n\n\t\t\t// Monitor events that trigger a change in state\n\t\t\tReveal.addEventListener( 'slidechanged', post );\n\t\t\tReveal.addEventListener( 'fragmentshown', post );\n\t\t\tReveal.addEventListener( 'fragmenthidden', post );\n\t\t\tReveal.addEventListener( 'overviewhidden', post );\n\t\t\tReveal.addEventListener( 'overviewshown', post );\n\t\t\tReveal.addEventListener( 'paused', post );\n\t\t\tReveal.addEventListener( 'resumed', post );\n\n\t\t\t// Post the initial state\n\t\t\tpost();\n\n\t\t}\n\n\t\tconnect();\n\n\t}\n\n\tif( !/receiver/i.test( window.location.search ) ) {\n\n\t\t// If the there's a 'notes' query set, open directly\n\t\tif( window.location.search.match( /(\\?|\\&)notes/gi ) !== null ) {\n\t\t\topenNotes();\n\t\t}\n\n\t\t// Open the notes when the 's' key is hit\n\t\tdocument.addEventListener( 'keydown', function( event ) {\n\t\t\t// Disregard the event if the target is editable or a\n\t\t\t// modifier is present\n\t\t\tif ( document.querySelector( ':focus' ) !== null || event.shiftKey || event.altKey || event.ctrlKey || event.metaKey ) return;\n\n\t\t\t// Disregard the event if keyboard is disabled\n\t\t\tif ( Reveal.getConfig().keyboard === false ) return;\n\n\t\t\tif( event.keyCode === 83 ) {\n\t\t\t\tevent.preventDefault();\n\t\t\t\topenNotes();\n\t\t\t}\n\t\t}, false );\n\n\t\t// Show our keyboard shortcut in the reveal.js help overlay\n\t\tif( window.Reveal ) Reveal.registerKeyboardShortcut( 'S', 'Speaker notes view' );\n\n\t}\n\n\treturn { open: openNotes };\n\n})();\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;","sourceRoot":""}\n//# sourceURL=webpack-internal:///./node_modules/reveal.js/plugin/notes/notes.js\n");
  17. /***/ }),
  18. /***/ "./node_modules/reveal.js/plugin/zoom-js/zoom.js":
  19. /*!*******************************************************!*\
  20. !*** ./node_modules/reveal.js/plugin/zoom-js/zoom.js ***!
  21. \*******************************************************/
  22. /*! no static exports found */
  23. /***/ (function(module, exports) {
  24. eval("// Custom reveal.js integration\n(function(){\n\tvar revealElement = document.querySelector( '.reveal' );\n\tif( revealElement ) {\n\n\t\trevealElement.addEventListener( 'mousedown', function( event ) {\n\t\t\tvar defaultModifier = /Linux/.test( window.navigator.platform ) ? 'ctrl' : 'alt';\n\n\t\t\tvar modifier = ( Reveal.getConfig().zoomKey ? Reveal.getConfig().zoomKey : defaultModifier ) + 'Key';\n\t\t\tvar zoomLevel = ( Reveal.getConfig().zoomLevel ? Reveal.getConfig().zoomLevel : 2 );\n\n\t\t\tif( event[ modifier ] && !Reveal.isOverview() ) {\n\t\t\t\tevent.preventDefault();\n\n\t\t\t\tzoom.to({\n\t\t\t\t\tx: event.clientX,\n\t\t\t\t\ty: event.clientY,\n\t\t\t\t\tscale: zoomLevel,\n\t\t\t\t\tpan: false\n\t\t\t\t});\n\t\t\t}\n\t\t} );\n\n\t}\n})();\n\n/*!\n * zoom.js 0.3 (modified for use with reveal.js)\n * http://lab.hakim.se/zoom-js\n * MIT licensed\n *\n * Copyright (C) 2011-2014 Hakim El Hattab, http://hakim.se\n */\nvar zoom = (function(){\n\n\t// The current zoom level (scale)\n\tvar level = 1;\n\n\t// The current mouse position, used for panning\n\tvar mouseX = 0,\n\t\tmouseY = 0;\n\n\t// Timeout before pan is activated\n\tvar panEngageTimeout = -1,\n\t\tpanUpdateInterval = -1;\n\n\t// Check for transform support so that we can fallback otherwise\n\tvar supportsTransforms = \t'WebkitTransform' in document.body.style ||\n\t\t\t\t\t\t\t\t'MozTransform' in document.body.style ||\n\t\t\t\t\t\t\t\t'msTransform' in document.body.style ||\n\t\t\t\t\t\t\t\t'OTransform' in document.body.style ||\n\t\t\t\t\t\t\t\t'transform' in document.body.style;\n\n\tif( supportsTransforms ) {\n\t\t// The easing that will be applied when we zoom in/out\n\t\tdocument.body.style.transition = 'transform 0.8s ease';\n\t\tdocument.body.style.OTransition = '-o-transform 0.8s ease';\n\t\tdocument.body.style.msTransition = '-ms-transform 0.8s ease';\n\t\tdocument.body.style.MozTransition = '-moz-transform 0.8s ease';\n\t\tdocument.body.style.WebkitTransition = '-webkit-transform 0.8s ease';\n\t}\n\n\t// Zoom out if the user hits escape\n\tdocument.addEventListener( 'keyup', function( event ) {\n\t\tif( level !== 1 && event.keyCode === 27 ) {\n\t\t\tzoom.out();\n\t\t}\n\t} );\n\n\t// Monitor mouse movement for panning\n\tdocument.addEventListener( 'mousemove', function( event ) {\n\t\tif( level !== 1 ) {\n\t\t\tmouseX = event.clientX;\n\t\t\tmouseY = event.clientY;\n\t\t}\n\t} );\n\n\t/**\n\t * Applies the CSS required to zoom in, prefers the use of CSS3\n\t * transforms but falls back on zoom for IE.\n\t *\n\t * @param {Object} rect\n\t * @param {Number} scale\n\t */\n\tfunction magnify( rect, scale ) {\n\n\t\tvar scrollOffset = getScrollOffset();\n\n\t\t// Ensure a width/height is set\n\t\trect.width = rect.width || 1;\n\t\trect.height = rect.height || 1;\n\n\t\t// Center the rect within the zoomed viewport\n\t\trect.x -= ( window.innerWidth - ( rect.width * scale ) ) / 2;\n\t\trect.y -= ( window.innerHeight - ( rect.height * scale ) ) / 2;\n\n\t\tif( supportsTransforms ) {\n\t\t\t// Reset\n\t\t\tif( scale === 1 ) {\n\t\t\t\tdocument.body.style.transform = '';\n\t\t\t\tdocument.body.style.OTransform = '';\n\t\t\t\tdocument.body.style.msTransform = '';\n\t\t\t\tdocument.body.style.MozTransform = '';\n\t\t\t\tdocument.body.style.WebkitTransform = '';\n\t\t\t}\n\t\t\t// Scale\n\t\t\telse {\n\t\t\t\tvar origin = scrollOffset.x +'px '+ scrollOffset.y +'px',\n\t\t\t\t\ttransform = 'translate('+ -rect.x +'px,'+ -rect.y +'px) scale('+ scale +')';\n\n\t\t\t\tdocument.body.style.transformOrigin = origin;\n\t\t\t\tdocument.body.style.OTransformOrigin = origin;\n\t\t\t\tdocument.body.style.msTransformOrigin = origin;\n\t\t\t\tdocument.body.style.MozTransformOrigin = origin;\n\t\t\t\tdocument.body.style.WebkitTransformOrigin = origin;\n\n\t\t\t\tdocument.body.style.transform = transform;\n\t\t\t\tdocument.body.style.OTransform = transform;\n\t\t\t\tdocument.body.style.msTransform = transform;\n\t\t\t\tdocument.body.style.MozTransform = transform;\n\t\t\t\tdocument.body.style.WebkitTransform = transform;\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\t// Reset\n\t\t\tif( scale === 1 ) {\n\t\t\t\tdocument.body.style.position = '';\n\t\t\t\tdocument.body.style.left = '';\n\t\t\t\tdocument.body.style.top = '';\n\t\t\t\tdocument.body.style.width = '';\n\t\t\t\tdocument.body.style.height = '';\n\t\t\t\tdocument.body.style.zoom = '';\n\t\t\t}\n\t\t\t// Scale\n\t\t\telse {\n\t\t\t\tdocument.body.style.position = 'relative';\n\t\t\t\tdocument.body.style.left = ( - ( scrollOffset.x + rect.x ) / scale ) + 'px';\n\t\t\t\tdocument.body.style.top = ( - ( scrollOffset.y + rect.y ) / scale ) + 'px';\n\t\t\t\tdocument.body.style.width = ( scale * 100 ) + '%';\n\t\t\t\tdocument.body.style.height = ( scale * 100 ) + '%';\n\t\t\t\tdocument.body.style.zoom = scale;\n\t\t\t}\n\t\t}\n\n\t\tlevel = scale;\n\n\t\tif( document.documentElement.classList ) {\n\t\t\tif( level !== 1 ) {\n\t\t\t\tdocument.documentElement.classList.add( 'zoomed' );\n\t\t\t}\n\t\t\telse {\n\t\t\t\tdocument.documentElement.classList.remove( 'zoomed' );\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Pan the document when the mosue cursor approaches the edges\n\t * of the window.\n\t */\n\tfunction pan() {\n\t\tvar range = 0.12,\n\t\t\trangeX = window.innerWidth * range,\n\t\t\trangeY = window.innerHeight * range,\n\t\t\tscrollOffset = getScrollOffset();\n\n\t\t// Up\n\t\tif( mouseY < rangeY ) {\n\t\t\twindow.scroll( scrollOffset.x, scrollOffset.y - ( 1 - ( mouseY / rangeY ) ) * ( 14 / level ) );\n\t\t}\n\t\t// Down\n\t\telse if( mouseY > window.innerHeight - rangeY ) {\n\t\t\twindow.scroll( scrollOffset.x, scrollOffset.y + ( 1 - ( window.innerHeight - mouseY ) / rangeY ) * ( 14 / level ) );\n\t\t}\n\n\t\t// Left\n\t\tif( mouseX < rangeX ) {\n\t\t\twindow.scroll( scrollOffset.x - ( 1 - ( mouseX / rangeX ) ) * ( 14 / level ), scrollOffset.y );\n\t\t}\n\t\t// Right\n\t\telse if( mouseX > window.innerWidth - rangeX ) {\n\t\t\twindow.scroll( scrollOffset.x + ( 1 - ( window.innerWidth - mouseX ) / rangeX ) * ( 14 / level ), scrollOffset.y );\n\t\t}\n\t}\n\n\tfunction getScrollOffset() {\n\t\treturn {\n\t\t\tx: window.scrollX !== undefined ? window.scrollX : window.pageXOffset,\n\t\t\ty: window.scrollY !== undefined ? window.scrollY : window.pageYOffset\n\t\t}\n\t}\n\n\treturn {\n\t\t/**\n\t\t * Zooms in on either a rectangle or HTML element.\n\t\t *\n\t\t * @param {Object} options\n\t\t * - element: HTML element to zoom in on\n\t\t * OR\n\t\t * - x/y: coordinates in non-transformed space to zoom in on\n\t\t * - width/height: the portion of the screen to zoom in on\n\t\t * - scale: can be used instead of width/height to explicitly set scale\n\t\t */\n\t\tto: function( options ) {\n\n\t\t\t// Due to an implementation limitation we can't zoom in\n\t\t\t// to another element without zooming out first\n\t\t\tif( level !== 1 ) {\n\t\t\t\tzoom.out();\n\t\t\t}\n\t\t\telse {\n\t\t\t\toptions.x = options.x || 0;\n\t\t\t\toptions.y = options.y || 0;\n\n\t\t\t\t// If an element is set, that takes precedence\n\t\t\t\tif( !!options.element ) {\n\t\t\t\t\t// Space around the zoomed in element to leave on screen\n\t\t\t\t\tvar padding = 20;\n\t\t\t\t\tvar bounds = options.element.getBoundingClientRect();\n\n\t\t\t\t\toptions.x = bounds.left - padding;\n\t\t\t\t\toptions.y = bounds.top - padding;\n\t\t\t\t\toptions.width = bounds.width + ( padding * 2 );\n\t\t\t\t\toptions.height = bounds.height + ( padding * 2 );\n\t\t\t\t}\n\n\t\t\t\t// If width/height values are set, calculate scale from those values\n\t\t\t\tif( options.width !== undefined && options.height !== undefined ) {\n\t\t\t\t\toptions.scale = Math.max( Math.min( window.innerWidth / options.width, window.innerHeight / options.height ), 1 );\n\t\t\t\t}\n\n\t\t\t\tif( options.scale > 1 ) {\n\t\t\t\t\toptions.x *= options.scale;\n\t\t\t\t\toptions.y *= options.scale;\n\n\t\t\t\t\tmagnify( options, options.scale );\n\n\t\t\t\t\tif( options.pan !== false ) {\n\n\t\t\t\t\t\t// Wait with engaging panning as it may conflict with the\n\t\t\t\t\t\t// zoom transition\n\t\t\t\t\t\tpanEngageTimeout = setTimeout( function() {\n\t\t\t\t\t\t\tpanUpdateInterval = setInterval( pan, 1000 / 60 );\n\t\t\t\t\t\t}, 800 );\n\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Resets the document zoom state to its default.\n\t\t */\n\t\tout: function() {\n\t\t\tclearTimeout( panEngageTimeout );\n\t\t\tclearInterval( panUpdateInterval );\n\n\t\t\tmagnify( { x: 0, y: 0 }, 1 );\n\n\t\t\tlevel = 1;\n\t\t},\n\n\t\t// Alias\n\t\tmagnify: function( options ) { this.to( options ) },\n\t\treset: function() { this.out() },\n\n\t\tzoomLevel: function() {\n\t\t\treturn level;\n\t\t}\n\t}\n\n})();\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./node_modules/reveal.js/plugin/zoom-js/zoom.js.js","sources":["webpack:///./node_modules/reveal.js/plugin/zoom-js/zoom.js?ba60"],"sourcesContent":["// Custom reveal.js integration\n(function(){\n\tvar revealElement = document.querySelector( '.reveal' );\n\tif( revealElement ) {\n\n\t\trevealElement.addEventListener( 'mousedown', function( event ) {\n\t\t\tvar defaultModifier = /Linux/.test( window.navigator.platform ) ? 'ctrl' : 'alt';\n\n\t\t\tvar modifier = ( Reveal.getConfig().zoomKey ? Reveal.getConfig().zoomKey : defaultModifier ) + 'Key';\n\t\t\tvar zoomLevel = ( Reveal.getConfig().zoomLevel ? Reveal.getConfig().zoomLevel : 2 );\n\n\t\t\tif( event[ modifier ] && !Reveal.isOverview() ) {\n\t\t\t\tevent.preventDefault();\n\n\t\t\t\tzoom.to({\n\t\t\t\t\tx: event.clientX,\n\t\t\t\t\ty: event.clientY,\n\t\t\t\t\tscale: zoomLevel,\n\t\t\t\t\tpan: false\n\t\t\t\t});\n\t\t\t}\n\t\t} );\n\n\t}\n})();\n\n/*!\n * zoom.js 0.3 (modified for use with reveal.js)\n * http://lab.hakim.se/zoom-js\n * MIT licensed\n *\n * Copyright (C) 2011-2014 Hakim El Hattab, http://hakim.se\n */\nvar zoom = (function(){\n\n\t// The current zoom level (scale)\n\tvar level = 1;\n\n\t// The current mouse position, used for panning\n\tvar mouseX = 0,\n\t\tmouseY = 0;\n\n\t// Timeout before pan is activated\n\tvar panEngageTimeout = -1,\n\t\tpanUpdateInterval = -1;\n\n\t// Check for transform support so that we can fallback otherwise\n\tvar supportsTransforms = \t'WebkitTransform' in document.body.style ||\n\t\t\t\t\t\t\t\t'MozTransform' in document.body.style ||\n\t\t\t\t\t\t\t\t'msTransform' in document.body.style ||\n\t\t\t\t\t\t\t\t'OTransform' in document.body.style ||\n\t\t\t\t\t\t\t\t'transform' in document.body.style;\n\n\tif( supportsTransforms ) {\n\t\t// The easing that will be applied when we zoom in/out\n\t\tdocument.body.style.transition = 'transform 0.8s ease';\n\t\tdocument.body.style.OTransition = '-o-transform 0.8s ease';\n\t\tdocument.body.style.msTransition = '-ms-transform 0.8s ease';\n\t\tdocument.body.style.MozTransition = '-moz-transform 0.8s ease';\n\t\tdocument.body.style.WebkitTransition = '-webkit-transform 0.8s ease';\n\t}\n\n\t// Zoom out if the user hits escape\n\tdocument.addEventListener( 'keyup', function( event ) {\n\t\tif( level !== 1 && event.keyCode === 27 ) {\n\t\t\tzoom.out();\n\t\t}\n\t} );\n\n\t// Monitor mouse movement for panning\n\tdocument.addEventListener( 'mousemove', function( event ) {\n\t\tif( level !== 1 ) {\n\t\t\tmouseX = event.clientX;\n\t\t\tmouseY = event.clientY;\n\t\t}\n\t} );\n\n\t/**\n\t * Applies the CSS required to zoom in, prefers the use of CSS3\n\t * transforms but falls back on zoom for IE.\n\t *\n\t * @param {Object} rect\n\t * @param {Number} scale\n\t */\n\tfunction magnify( rect, scale ) {\n\n\t\tvar scrollOffset = getScrollOffset();\n\n\t\t// Ensure a width/height is set\n\t\trect.width = rect.width || 1;\n\t\trect.height = rect.height || 1;\n\n\t\t// Center the rect within the zoomed viewport\n\t\trect.x -= ( window.innerWidth - ( rect.width * scale ) ) / 2;\n\t\trect.y -= ( window.innerHeight - ( rect.height * scale ) ) / 2;\n\n\t\tif( supportsTransforms ) {\n\t\t\t// Reset\n\t\t\tif( scale === 1 ) {\n\t\t\t\tdocument.body.style.transform = '';\n\t\t\t\tdocument.body.style.OTransform = '';\n\t\t\t\tdocument.body.style.msTransform = '';\n\t\t\t\tdocument.body.style.MozTransform = '';\n\t\t\t\tdocument.body.style.WebkitTransform = '';\n\t\t\t}\n\t\t\t// Scale\n\t\t\telse {\n\t\t\t\tvar origin = scrollOffset.x +'px '+ scrollOffset.y +'px',\n\t\t\t\t\ttransform = 'translate('+ -rect.x +'px,'+ -rect.y +'px) scale('+ scale +')';\n\n\t\t\t\tdocument.body.style.transformOrigin = origin;\n\t\t\t\tdocument.body.style.OTransformOrigin = origin;\n\t\t\t\tdocument.body.style.msTransformOrigin = origin;\n\t\t\t\tdocument.body.style.MozTransformOrigin = origin;\n\t\t\t\tdocument.body.style.WebkitTransformOrigin = origin;\n\n\t\t\t\tdocument.body.style.transform = transform;\n\t\t\t\tdocument.body.style.OTransform = transform;\n\t\t\t\tdocument.body.style.msTransform = transform;\n\t\t\t\tdocument.body.style.MozTransform = transform;\n\t\t\t\tdocument.body.style.WebkitTransform = transform;\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\t// Reset\n\t\t\tif( scale === 1 ) {\n\t\t\t\tdocument.body.style.position = '';\n\t\t\t\tdocument.body.style.left = '';\n\t\t\t\tdocument.body.style.top = '';\n\t\t\t\tdocument.body.style.width = '';\n\t\t\t\tdocument.body.style.height = '';\n\t\t\t\tdocument.body.style.zoom = '';\n\t\t\t}\n\t\t\t// Scale\n\t\t\telse {\n\t\t\t\tdocument.body.style.position = 'relative';\n\t\t\t\tdocument.body.style.left = ( - ( scrollOffset.x + rect.x ) / scale ) + 'px';\n\t\t\t\tdocument.body.style.top = ( - ( scrollOffset.y + rect.y ) / scale ) + 'px';\n\t\t\t\tdocument.body.style.width = ( scale * 100 ) + '%';\n\t\t\t\tdocument.body.style.height = ( scale * 100 ) + '%';\n\t\t\t\tdocument.body.style.zoom = scale;\n\t\t\t}\n\t\t}\n\n\t\tlevel = scale;\n\n\t\tif( document.documentElement.classList ) {\n\t\t\tif( level !== 1 ) {\n\t\t\t\tdocument.documentElement.classList.add( 'zoomed' );\n\t\t\t}\n\t\t\telse {\n\t\t\t\tdocument.documentElement.classList.remove( 'zoomed' );\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Pan the document when the mosue cursor approaches the edges\n\t * of the window.\n\t */\n\tfunction pan() {\n\t\tvar range = 0.12,\n\t\t\trangeX = window.innerWidth * range,\n\t\t\trangeY = window.innerHeight * range,\n\t\t\tscrollOffset = getScrollOffset();\n\n\t\t// Up\n\t\tif( mouseY < rangeY ) {\n\t\t\twindow.scroll( scrollOffset.x, scrollOffset.y - ( 1 - ( mouseY / rangeY ) ) * ( 14 / level ) );\n\t\t}\n\t\t// Down\n\t\telse if( mouseY > window.innerHeight - rangeY ) {\n\t\t\twindow.scroll( scrollOffset.x, scrollOffset.y + ( 1 - ( window.innerHeight - mouseY ) / rangeY ) * ( 14 / level ) );\n\t\t}\n\n\t\t// Left\n\t\tif( mouseX < rangeX ) {\n\t\t\twindow.scroll( scrollOffset.x - ( 1 - ( mouseX / rangeX ) ) * ( 14 / level ), scrollOffset.y );\n\t\t}\n\t\t// Right\n\t\telse if( mouseX > window.innerWidth - rangeX ) {\n\t\t\twindow.scroll( scrollOffset.x + ( 1 - ( window.innerWidth - mouseX ) / rangeX ) * ( 14 / level ), scrollOffset.y );\n\t\t}\n\t}\n\n\tfunction getScrollOffset() {\n\t\treturn {\n\t\t\tx: window.scrollX !== undefined ? window.scrollX : window.pageXOffset,\n\t\t\ty: window.scrollY !== undefined ? window.scrollY : window.pageYOffset\n\t\t}\n\t}\n\n\treturn {\n\t\t/**\n\t\t * Zooms in on either a rectangle or HTML element.\n\t\t *\n\t\t * @param {Object} options\n\t\t *   - element: HTML element to zoom in on\n\t\t *   OR\n\t\t *   - x/y: coordinates in non-transformed space to zoom in on\n\t\t *   - width/height: the portion of the screen to zoom in on\n\t\t *   - scale: can be used instead of width/height to explicitly set scale\n\t\t */\n\t\tto: function( options ) {\n\n\t\t\t// Due to an implementation limitation we can't zoom in\n\t\t\t// to another element without zooming out first\n\t\t\tif( level !== 1 ) {\n\t\t\t\tzoom.out();\n\t\t\t}\n\t\t\telse {\n\t\t\t\toptions.x = options.x || 0;\n\t\t\t\toptions.y = options.y || 0;\n\n\t\t\t\t// If an element is set, that takes precedence\n\t\t\t\tif( !!options.element ) {\n\t\t\t\t\t// Space around the zoomed in element to leave on screen\n\t\t\t\t\tvar padding = 20;\n\t\t\t\t\tvar bounds = options.element.getBoundingClientRect();\n\n\t\t\t\t\toptions.x = bounds.left - padding;\n\t\t\t\t\toptions.y = bounds.top - padding;\n\t\t\t\t\toptions.width = bounds.width + ( padding * 2 );\n\t\t\t\t\toptions.height = bounds.height + ( padding * 2 );\n\t\t\t\t}\n\n\t\t\t\t// If width/height values are set, calculate scale from those values\n\t\t\t\tif( options.width !== undefined && options.height !== undefined ) {\n\t\t\t\t\toptions.scale = Math.max( Math.min( window.innerWidth / options.width, window.innerHeight / options.height ), 1 );\n\t\t\t\t}\n\n\t\t\t\tif( options.scale > 1 ) {\n\t\t\t\t\toptions.x *= options.scale;\n\t\t\t\t\toptions.y *= options.scale;\n\n\t\t\t\t\tmagnify( options, options.scale );\n\n\t\t\t\t\tif( options.pan !== false ) {\n\n\t\t\t\t\t\t// Wait with engaging panning as it may conflict with the\n\t\t\t\t\t\t// zoom transition\n\t\t\t\t\t\tpanEngageTimeout = setTimeout( function() {\n\t\t\t\t\t\t\tpanUpdateInterval = setInterval( pan, 1000 / 60 );\n\t\t\t\t\t\t}, 800 );\n\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Resets the document zoom state to its default.\n\t\t */\n\t\tout: function() {\n\t\t\tclearTimeout( panEngageTimeout );\n\t\t\tclearInterval( panUpdateInterval );\n\n\t\t\tmagnify( { x: 0, y: 0 }, 1 );\n\n\t\t\tlevel = 1;\n\t\t},\n\n\t\t// Alias\n\t\tmagnify: function( options ) { this.to( options ) },\n\t\treset: function() { this.out() },\n\n\t\tzoomLevel: function() {\n\t\t\treturn level;\n\t\t}\n\t}\n\n})();\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;","sourceRoot":""}\n//# sourceURL=webpack-internal:///./node_modules/reveal.js/plugin/zoom-js/zoom.js\n");
  25. /***/ }),
  26. /***/ "./src/client/js/util/reveal/plugins/growi-renderer.js":
  27. /*!*************************************************************!*\
  28. !*** ./src/client/js/util/reveal/plugins/growi-renderer.js ***!
  29. \*************************************************************/
  30. /*! no static exports found */
  31. /***/ (function(module, exports, __webpack_require__) {
  32. eval("/**\n * reveal.js growi-renderer plugin.\n */\n(function (root, factory) {\n // get AppContainer instance from parent window\n const appContainer = window.parent.appContainer;\n const growiRendererPlugin = factory(appContainer);\n growiRendererPlugin.initialize();\n})(this, appContainer => {\n /* eslint-disable no-useless-escape */\n const DEFAULT_SLIDE_SEPARATOR = '^\\r?\\n---\\r?\\n$';\n const DEFAULT_ELEMENT_ATTRIBUTES_SEPARATOR = '\\\\\\.element\\\\\\s*?(.+?)$';\n const DEFAULT_SLIDE_ATTRIBUTES_SEPARATOR = '\\\\\\.slide:\\\\\\s*?(\\\\\\S.+?)$';\n /* eslint-enable no-useless-escape */\n\n const growiRenderer = appContainer.getRenderer('editor');\n let marked;\n /**\n * Add data separator before lines\n * starting with '#' to markdown.\n */\n\n function divideSlides() {\n const sections = document.querySelectorAll('[data-markdown]');\n\n for (let i = 0, len = sections.length; i < len; i++) {\n const section = sections[i];\n const markdown = marked.getMarkdownFromSlide(section);\n const context = {\n markdown\n };\n const interceptorManager = appContainer.interceptorManager;\n let dataSeparator = section.getAttribute('data-separator') || DEFAULT_SLIDE_SEPARATOR; // replace string '\\n' to LF code.\n\n dataSeparator = dataSeparator.replace(/\\\\n/g, '\\n');\n const replaceValue = `${dataSeparator}#`; // detach code block.\n\n interceptorManager.process('prePreProcess', context); // if there is only '\\n' in the first line, replace it.\n\n context.markdown = context.markdown.replace(/^\\n/, ''); // add data separator to markdown.\n\n context.markdown = context.markdown.replace(/[\\n]+#/g, replaceValue); // restore code block.\n\n interceptorManager.process('postPreProcess', context);\n section.innerHTML = marked.createMarkdownSlide(context.markdown);\n }\n }\n /**\n * Converts data-markdown slides to HTML slides by GrowiRenderer.\n */\n\n\n function convertSlides() {\n const sections = document.querySelectorAll('[data-markdown]');\n let markdown;\n const interceptorManager = appContainer.interceptorManager;\n\n for (let i = 0, len = sections.length; i < len; i++) {\n const section = sections[i]; // Only parse the same slide once\n\n if (!section.getAttribute('data-markdown-parsed')) {\n section.setAttribute('data-markdown-parsed', 'true');\n const notes = section.querySelector('aside.notes');\n markdown = marked.getMarkdownFromSlide(section);\n const context = {\n markdown\n };\n interceptorManager.process('preRender', context).then(() => {\n return interceptorManager.process('prePreProcess', context);\n }).then(() => {\n context.markdown = growiRenderer.preProcess(context.markdown);\n }).then(() => {\n return interceptorManager.process('postPreProcess', context);\n }).then(() => {\n context.parsedHTML = growiRenderer.process(context.markdown);\n }).then(() => {\n return interceptorManager.process('prePostProcess', context);\n }).then(() => {\n context.parsedHTML = growiRenderer.postProcess(context.parsedHTML);\n }).then(() => {\n return interceptorManager.process('postPostProcess', context);\n }).then(() => {\n return interceptorManager.process('preRenderHtml', context);\n }).then(() => {\n return interceptorManager.process('postRenderHtml', context);\n }).then(() => {\n section.innerHTML = context.parsedHTML;\n });\n marked.addAttributes(section, section, null, section.getAttribute('data-element-attributes') || section.parentNode.getAttribute('data-element-attributes') || DEFAULT_ELEMENT_ATTRIBUTES_SEPARATOR, section.getAttribute('data-attributes') || section.parentNode.getAttribute('data-attributes') || DEFAULT_SLIDE_ATTRIBUTES_SEPARATOR); // If there were notes, we need to re-add them after\n // having overwritten the section's HTML\n\n if (notes) {\n section.appendChild(notes);\n }\n }\n }\n } // API\n\n\n return {\n async initialize() {\n marked = __webpack_require__(/*! ./markdown */ \"./src/client/js/util/reveal/plugins/markdown.js\").default(growiRenderer.process);\n divideSlides();\n marked.processSlides();\n convertSlides();\n }\n\n };\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvY2xpZW50L2pzL3V0aWwvcmV2ZWFsL3BsdWdpbnMvZ3Jvd2ktcmVuZGVyZXIuanMuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9zcmMvY2xpZW50L2pzL3V0aWwvcmV2ZWFsL3BsdWdpbnMvZ3Jvd2ktcmVuZGVyZXIuanM/ZmJkZCJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIHJldmVhbC5qcyBncm93aS1yZW5kZXJlciBwbHVnaW4uXG4gKi9cbihmdW5jdGlvbihyb290LCBmYWN0b3J5KSB7XG4gIC8vIGdldCBBcHBDb250YWluZXIgaW5zdGFuY2UgZnJvbSBwYXJlbnQgd2luZG93XG4gIGNvbnN0IGFwcENvbnRhaW5lciA9IHdpbmRvdy5wYXJlbnQuYXBwQ29udGFpbmVyO1xuXG4gIGNvbnN0IGdyb3dpUmVuZGVyZXJQbHVnaW4gPSBmYWN0b3J5KGFwcENvbnRhaW5lcik7XG4gIGdyb3dpUmVuZGVyZXJQbHVnaW4uaW5pdGlhbGl6ZSgpO1xufSh0aGlzLCAoYXBwQ29udGFpbmVyKSA9PiB7XG4gIC8qIGVzbGludC1kaXNhYmxlIG5vLXVzZWxlc3MtZXNjYXBlICovXG4gIGNvbnN0IERFRkFVTFRfU0xJREVfU0VQQVJBVE9SID0gJ15cXHI/XFxuLS0tXFxyP1xcbiQnO1xuICBjb25zdCBERUZBVUxUX0VMRU1FTlRfQVRUUklCVVRFU19TRVBBUkFUT1IgPSAnXFxcXFxcLmVsZW1lbnRcXFxcXFxzKj8oLis/KSQnO1xuICBjb25zdCBERUZBVUxUX1NMSURFX0FUVFJJQlVURVNfU0VQQVJBVE9SID0gJ1xcXFxcXC5zbGlkZTpcXFxcXFxzKj8oXFxcXFxcUy4rPykkJztcbiAgLyogZXNsaW50LWVuYWJsZSBuby11c2VsZXNzLWVzY2FwZSAqL1xuXG4gIGNvbnN0IGdyb3dpUmVuZGVyZXIgPSBhcHBDb250YWluZXIuZ2V0UmVuZGVyZXIoJ2VkaXRvcicpO1xuXG4gIGxldCBtYXJrZWQ7XG5cbiAgLyoqXG4gICAqIEFkZCBkYXRhIHNlcGFyYXRvciBiZWZvcmUgbGluZXNcbiAgICogc3RhcnRpbmcgd2l0aCAnIycgdG8gbWFya2Rvd24uXG4gICAqL1xuICBmdW5jdGlvbiBkaXZpZGVTbGlkZXMoKSB7XG4gICAgY29uc3Qgc2VjdGlvbnMgPSBkb2N1bWVudC5xdWVyeVNlbGVjdG9yQWxsKCdbZGF0YS1tYXJrZG93bl0nKTtcbiAgICBmb3IgKGxldCBpID0gMCwgbGVuID0gc2VjdGlvbnMubGVuZ3RoOyBpIDwgbGVuOyBpKyspIHtcbiAgICAgIGNvbnN0IHNlY3Rpb24gPSBzZWN0aW9uc1tpXTtcbiAgICAgIGNvbnN0IG1hcmtkb3duID0gbWFya2VkLmdldE1hcmtkb3duRnJvbVNsaWRlKHNlY3Rpb24pO1xuICAgICAgY29uc3QgY29udGV4dCA9IHsgbWFya2Rvd24gfTtcbiAgICAgIGNvbnN0IGludGVyY2VwdG9yTWFuYWdlciA9IGFwcENvbnRhaW5lci5pbnRlcmNlcHRvck1hbmFnZXI7XG4gICAgICBsZXQgZGF0YVNlcGFyYXRvciA9IHNlY3Rpb24uZ2V0QXR0cmlidXRlKCdkYXRhLXNlcGFyYXRvcicpIHx8IERFRkFVTFRfU0xJREVfU0VQQVJBVE9SO1xuICAgICAgLy8gcmVwbGFjZSBzdHJpbmcgJ1xcbicgdG8gTEYgY29kZS5cbiAgICAgIGRhdGFTZXBhcmF0b3IgPSBkYXRhU2VwYXJhdG9yLnJlcGxhY2UoL1xcXFxuL2csICdcXG4nKTtcbiAgICAgIGNvbnN0IHJlcGxhY2VWYWx1ZSA9IGAke2RhdGFTZXBhcmF0b3J9I2A7XG4gICAgICAvLyBkZXRhY2ggY29kZSBibG9jay5cbiAgICAgIGludGVyY2VwdG9yTWFuYWdlci5wcm9jZXNzKCdwcmVQcmVQcm9jZXNzJywgY29udGV4dCk7XG4gICAgICAvLyBpZiB0aGVyZSBpcyBvbmx5ICdcXG4nIGluIHRoZSBmaXJzdCBsaW5lLCByZXBsYWNlIGl0LlxuICAgICAgY29udGV4dC5tYXJrZG93biA9IGNvbnRleHQubWFya2Rvd24ucmVwbGFjZSgvXlxcbi8sICcnKTtcbiAgICAgIC8vIGFkZCBkYXRhIHNlcGFyYXRvciB0byBtYXJrZG93bi5cbiAgICAgIGNvbnRleHQubWFya2Rvd24gPSBjb250ZXh0Lm1hcmtkb3duLnJlcGxhY2UoL1tcXG5dKyMvZywgcmVwbGFjZVZhbHVlKTtcbiAgICAgIC8vIHJlc3RvcmUgY29kZSBibG9jay5cbiAgICAgIGludGVyY2VwdG9yTWFuYWdlci5wcm9jZXNzKCdwb3N0UHJlUHJvY2VzcycsIGNvbnRleHQpO1xuICAgICAgc2VjdGlvbi5pbm5lckhUTUwgPSBtYXJrZWQuY3JlYXRlTWFya2Rvd25TbGlkZShjb250ZXh0Lm1hcmtkb3duKTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogQ29udmVydHMgZGF0YS1tYXJrZG93biBzbGlkZXMgdG8gSFRNTCBzbGlkZXMgYnkgR3Jvd2lSZW5kZXJlci5cbiAgICovXG4gIGZ1bmN0aW9uIGNvbnZlcnRTbGlkZXMoKSB7XG4gICAgY29uc3Qgc2VjdGlvbnMgPSBkb2N1bWVudC5xdWVyeVNlbGVjdG9yQWxsKCdbZGF0YS1tYXJrZG93bl0nKTtcbiAgICBsZXQgbWFya2Rvd247XG4gICAgY29uc3QgaW50ZXJjZXB0b3JNYW5hZ2VyID0gYXBwQ29udGFpbmVyLmludGVyY2VwdG9yTWFuYWdlcjtcblxuICAgIGZvciAobGV0IGkgPSAwLCBsZW4gPSBzZWN0aW9ucy5sZW5ndGg7IGkgPCBsZW47IGkrKykge1xuICAgICAgY29uc3Qgc2VjdGlvbiA9IHNlY3Rpb25zW2ldO1xuXG4gICAgICAvLyBPbmx5IHBhcnNlIHRoZSBzYW1lIHNsaWRlIG9uY2VcbiAgICAgIGlmICghc2VjdGlvbi5nZXRBdHRyaWJ1dGUoJ2RhdGEtbWFya2Rvd24tcGFyc2VkJykpIHtcbiAgICAgICAgc2VjdGlvbi5zZXRBdHRyaWJ1dGUoJ2RhdGEtbWFya2Rvd24tcGFyc2VkJywgJ3RydWUnKTtcbiAgICAgICAgY29uc3Qgbm90ZXMgPSBzZWN0aW9uLnF1ZXJ5U2VsZWN0b3IoJ2FzaWRlLm5vdGVzJyk7XG4gICAgICAgIG1hcmtkb3duID0gbWFya2VkLmdldE1hcmtkb3duRnJvbVNsaWRlKHNlY3Rpb24pO1xuICAgICAgICBjb25zdCBjb250ZXh0ID0geyBtYXJrZG93biB9O1xuXG4gICAgICAgIGludGVyY2VwdG9yTWFuYWdlci5wcm9jZXNzKCdwcmVSZW5kZXInLCBjb250ZXh0KVxuICAgICAgICAgIC50aGVuKCgpID0+IHsgcmV0dXJuIGludGVyY2VwdG9yTWFuYWdlci5wcm9jZXNzKCdwcmVQcmVQcm9jZXNzJywgY29udGV4dCkgfSlcbiAgICAgICAgICAudGhlbigoKSA9PiB7XG4gICAgICAgICAgICBjb250ZXh0Lm1hcmtkb3duID0gZ3Jvd2lSZW5kZXJlci5wcmVQcm9jZXNzKGNvbnRleHQubWFya2Rvd24pO1xuICAgICAgICAgIH0pXG4gICAgICAgICAgLnRoZW4oKCkgPT4geyByZXR1cm4gaW50ZXJjZXB0b3JNYW5hZ2VyLnByb2Nlc3MoJ3Bvc3RQcmVQcm9jZXNzJywgY29udGV4dCkgfSlcbiAgICAgICAgICAudGhlbigoKSA9PiB7XG4gICAgICAgICAgICBjb250ZXh0LnBhcnNlZEhUTUwgPSBncm93aVJlbmRlcmVyLnByb2Nlc3MoY29udGV4dC5tYXJrZG93bik7XG4gICAgICAgICAgfSlcbiAgICAgICAgICAudGhlbigoKSA9PiB7IHJldHVybiBpbnRlcmNlcHRvck1hbmFnZXIucHJvY2VzcygncHJlUG9zdFByb2Nlc3MnLCBjb250ZXh0KSB9KVxuICAgICAgICAgIC50aGVuKCgpID0+IHtcbiAgICAgICAgICAgIGNvbnRleHQucGFyc2VkSFRNTCA9IGdyb3dpUmVuZGVyZXIucG9zdFByb2Nlc3MoY29udGV4dC5wYXJzZWRIVE1MKTtcbiAgICAgICAgICB9KVxuICAgICAgICAgIC50aGVuKCgpID0+IHsgcmV0dXJuIGludGVyY2VwdG9yTWFuYWdlci5wcm9jZXNzKCdwb3N0UG9zdFByb2Nlc3MnLCBjb250ZXh0KSB9KVxuICAgICAgICAgIC50aGVuKCgpID0+IHsgcmV0dXJuIGludGVyY2VwdG9yTWFuYWdlci5wcm9jZXNzKCdwcmVSZW5kZXJIdG1sJywgY29udGV4dCkgfSlcbiAgICAgICAgICAudGhlbigoKSA9PiB7IHJldHVybiBpbnRlcmNlcHRvck1hbmFnZXIucHJvY2VzcygncG9zdFJlbmRlckh0bWwnLCBjb250ZXh0KSB9KVxuICAgICAgICAgIC50aGVuKCgpID0+IHtcbiAgICAgICAgICAgIHNlY3Rpb24uaW5uZXJIVE1MID0gY29udGV4dC5wYXJzZWRIVE1MO1xuICAgICAgICAgIH0pO1xuICAgICAgICBtYXJrZWQuYWRkQXR0cmlidXRlcyhzZWN0aW9uLCBzZWN0aW9uLCBudWxsLCBzZWN0aW9uLmdldEF0dHJpYnV0ZSgnZGF0YS1lbGVtZW50LWF0dHJpYnV0ZXMnKVxuICAgICAgICAgIHx8IHNlY3Rpb24ucGFyZW50Tm9kZS5nZXRBdHRyaWJ1dGUoJ2RhdGEtZWxlbWVudC1hdHRyaWJ1dGVzJylcbiAgICAgICAgICB8fCBERUZBVUxUX0VMRU1FTlRfQVRUUklCVVRFU19TRVBBUkFUT1IsXG4gICAgICAgIHNlY3Rpb24uZ2V0QXR0cmlidXRlKCdkYXRhLWF0dHJpYnV0ZXMnKVxuICAgICAgICAgIHx8IHNlY3Rpb24ucGFyZW50Tm9kZS5nZXRBdHRyaWJ1dGUoJ2RhdGEtYXR0cmlidXRlcycpXG4gICAgICAgICAgfHwgREVGQVVMVF9TTElERV9BVFRSSUJVVEVTX1NFUEFSQVRPUik7XG5cbiAgICAgICAgLy8gSWYgdGhlcmUgd2VyZSBub3Rlcywgd2UgbmVlZCB0byByZS1hZGQgdGhlbSBhZnRlclxuICAgICAgICAvLyBoYXZpbmcgb3ZlcndyaXR0ZW4gdGhlIHNlY3Rpb24ncyBIVE1MXG4gICAgICAgIGlmIChub3Rlcykge1xuICAgICAgICAgIHNlY3Rpb24uYXBwZW5kQ2hpbGQobm90ZXMpO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgLy8gQVBJXG4gIHJldHVybiB7XG4gICAgYXN5bmMgaW5pdGlhbGl6ZSgpIHtcbiAgICAgIG1hcmtlZCA9IHJlcXVpcmUoJy4vbWFya2Rvd24nKS5kZWZhdWx0KGdyb3dpUmVuZGVyZXIucHJvY2Vzcyk7XG4gICAgICBkaXZpZGVTbGlkZXMoKTtcbiAgICAgIG1hcmtlZC5wcm9jZXNzU2xpZGVzKCk7XG4gICAgICBjb252ZXJ0U2xpZGVzKCk7XG4gICAgfSxcbiAgfTtcbn0pKTtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7OztBQUdBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFFQTs7Ozs7QUFJQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBOzs7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFBQTtBQUVBO0FBQ0E7QUFBQTtBQUVBO0FBQ0E7QUFDQTtBQUFBO0FBRUE7QUFDQTtBQUNBO0FBQUE7QUFFQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBRUE7QUFDQTtBQUNBO0FBUUE7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBUEE7QUFRQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/client/js/util/reveal/plugins/growi-renderer.js\n");
  33. /***/ }),
  34. /***/ "./src/client/js/util/reveal/plugins/markdown.js":
  35. /*!*******************************************************!*\
  36. !*** ./src/client/js/util/reveal/plugins/markdown.js ***!
  37. \*******************************************************/
  38. /*! exports provided: default */
  39. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  40. "use strict";
  41. eval("__webpack_require__.r(__webpack_exports__);\n/**\n * The reveal.js markdown plugin. Handles parsing of\n * markdown inside of presentations as well as loading\n * of external markdown documents.\n * Referred from The reveal.js markdown plugin.\n * https://github.com/hakimel/reveal.js/blob/master/plugin/markdown/markdown.js\n */\n/* harmony default export */ __webpack_exports__[\"default\"] = (function (marked) {\n const DEFAULT_SLIDE_SEPARATOR = '^\\r?\\n---\\r?\\n$',\n DEFAULT_NOTES_SEPARATOR = 'notes?:',\n DEFAULT_ELEMENT_ATTRIBUTES_SEPARATOR = '\\\\\\.element\\\\\\s*?(.+?)$',\n DEFAULT_SLIDE_ATTRIBUTES_SEPARATOR = '\\\\\\.slide:\\\\\\s*?(\\\\\\S.+?)$';\n const SCRIPT_END_PLACEHOLDER = '__SCRIPT_END__';\n /**\n * Retrieves the markdown contents of a slide section\n * element. Normalizes leading tabs/whitespace.\n */\n\n function getMarkdownFromSlide(section) {\n // look for a <script> or <textarea data-template> wrapper\n let template = section.querySelector('[data-template]') || section.querySelector('script'); // strip leading whitespace so it isn't evaluated as code\n\n let text = (template || section).textContent; // restore script end tags\n\n text = text.replace(new RegExp(SCRIPT_END_PLACEHOLDER, 'g'), '</script>');\n let leadingWs = text.match(/^\\n?(\\s*)/)[1].length,\n leadingTabs = text.match(/^\\n?(\\t*)/)[1].length;\n\n if (leadingTabs > 0) {\n text = text.replace(new RegExp('\\\\n?\\\\t{' + leadingTabs + '}', 'g'), '\\n');\n } else if (leadingWs > 1) {\n text = text.replace(new RegExp('\\\\n? {' + leadingWs + '}', 'g'), '\\n');\n }\n\n return text;\n }\n /**\n * Given a markdown slide section element, this will\n * return all arguments that aren't related to markdown\n * parsing. Used to forward any other user-defined arguments\n * to the output markdown slide.\n */\n\n\n function getForwardedAttributes(section) {\n let attributes = section.attributes;\n let result = [];\n\n for (let i = 0, len = attributes.length; i < len; i++) {\n let name = attributes[i].name,\n value = attributes[i].value; // disregard attributes that are used for markdown loading/parsing\n\n if (/data\\-(markdown|separator|vertical|notes)/gi.test(name)) continue;\n\n if (value) {\n result.push(name + '=\"' + value + '\"');\n } else {\n result.push(name);\n }\n }\n\n return result.join(' ');\n }\n /**\n * Inspects the given options and fills out default\n * values for what's not defined.\n */\n\n\n function getSlidifyOptions(options) {\n options = options || {};\n options.separator = options.separator || DEFAULT_SLIDE_SEPARATOR;\n options.notesSeparator = options.notesSeparator || DEFAULT_NOTES_SEPARATOR;\n options.attributes = options.attributes || '';\n return options;\n }\n /**\n * Helper function for constructing a markdown slide.\n */\n\n\n function createMarkdownSlide(content, options) {\n options = getSlidifyOptions(options);\n let notesMatch = content.split(new RegExp(options.notesSeparator, 'mgi'));\n\n if (notesMatch.length === 2) {\n content = notesMatch[0] + '<aside class=\"notes\">' + marked(notesMatch[1].trim()) + '</aside>';\n } // prevent script end tags in the content from interfering\n // with parsing\n\n\n content = content.replace(/<\\/script>/g, SCRIPT_END_PLACEHOLDER);\n return '<script type=\"text/template\">' + content + '</script>';\n }\n /**\n * Parses a data string into multiple slides based\n * on the passed in separator arguments.\n */\n\n\n function slidify(markdown, options) {\n options = getSlidifyOptions(options);\n let separatorRegex = new RegExp(options.separator + (options.verticalSeparator ? '|' + options.verticalSeparator : ''), 'mg'),\n horizontalSeparatorRegex = new RegExp(options.separator);\n let matches,\n lastIndex = 0,\n isHorizontal,\n wasHorizontal = true,\n content,\n sectionStack = []; // iterate until all blocks between separators are stacked up\n\n while ((matches = separatorRegex.exec(markdown)) != null) {\n // notes = null;\n // determine direction (horizontal by default)\n isHorizontal = horizontalSeparatorRegex.test(matches[0]);\n\n if (!isHorizontal && wasHorizontal) {\n // create vertical stack\n sectionStack.push([]);\n } // pluck slide content from markdown input\n\n\n content = markdown.substring(lastIndex, matches.index);\n\n if (isHorizontal && wasHorizontal) {\n // add to horizontal stack\n sectionStack.push(content);\n } else {\n // add to vertical stack\n sectionStack[sectionStack.length - 1].push(content);\n }\n\n lastIndex = separatorRegex.lastIndex;\n wasHorizontal = isHorizontal;\n } // add the remaining slide\n\n\n (wasHorizontal ? sectionStack : sectionStack[sectionStack.length - 1]).push(markdown.substring(lastIndex));\n let markdownSections = ''; // flatten the hierarchical stack, and insert <section data-markdown> tags\n\n for (let i = 0, len = sectionStack.length; i < len; i++) {\n // vertical\n if (sectionStack[i] instanceof Array) {\n markdownSections += '<section ' + options.attributes + '>';\n sectionStack[i].forEach(function (child) {\n markdownSections += '<section data-markdown>' + createMarkdownSlide(child, options) + '</section>';\n });\n markdownSections += '</section>';\n } else {\n markdownSections += '<section ' + options.attributes + ' data-markdown>' + createMarkdownSlide(sectionStack[i], options) + '</section>';\n }\n }\n\n return markdownSections;\n }\n /**\n * Parses any current data-markdown slides, splits\n * multi-slide markdown into separate sections and\n * handles loading of external markdown.\n */\n\n\n function processSlides() {\n let sections = document.querySelectorAll('[data-markdown]'),\n section;\n\n for (let i = 0, len = sections.length; i < len; i++) {\n section = sections[i];\n\n if (section.getAttribute('data-markdown').length) {\n let xhr = new XMLHttpRequest(),\n url = section.getAttribute('data-markdown');\n let datacharset = section.getAttribute('data-charset'); // see https://developer.mozilla.org/en-US/docs/Web/API/element.getAttribute#Notes\n\n if (datacharset != null && datacharset != '') {\n xhr.overrideMimeType('text/html; charset=' + datacharset);\n }\n\n xhr.onreadystatechange = function () {\n if (xhr.readyState === 4) {\n // file protocol yields status code 0 (useful for local debug, mobile applications etc.)\n if (xhr.status >= 200 && xhr.status < 300 || xhr.status === 0) {\n section.outerHTML = slidify(xhr.responseText, {\n separator: section.getAttribute('data-separator'),\n verticalSeparator: section.getAttribute('data-separator-vertical'),\n notesSeparator: section.getAttribute('data-separator-notes'),\n attributes: getForwardedAttributes(section)\n });\n } else {\n section.outerHTML = '<section data-state=\"alert\">' + 'ERROR: The attempt to fetch ' + url + ' failed with HTTP status ' + xhr.status + '.' + 'Check your browser\\'s JavaScript console for more details.' + '<p>Remember that you need to serve the presentation HTML from a HTTP server.</p>' + '</section>';\n }\n }\n };\n\n xhr.open('GET', url, false);\n\n try {\n xhr.send();\n } catch (e) {\n alert('Failed to get the Markdown file ' + url + '. Make sure that the presentation and the file are served by a HTTP server and the file can be found there. ' + e);\n }\n } else if (section.getAttribute('data-separator') || section.getAttribute('data-separator-vertical') || section.getAttribute('data-separator-notes')) {\n section.outerHTML = slidify(getMarkdownFromSlide(section), {\n separator: section.getAttribute('data-separator'),\n verticalSeparator: section.getAttribute('data-separator-vertical'),\n notesSeparator: section.getAttribute('data-separator-notes'),\n attributes: getForwardedAttributes(section)\n });\n } else {\n section.innerHTML = createMarkdownSlide(getMarkdownFromSlide(section));\n }\n }\n }\n /**\n * Check if a node value has the attributes pattern.\n * If yes, extract it and add that value as one or several attributes\n * the the terget element.\n *\n * You need Cache Killer on Chrome to see the effect on any FOM transformation\n * directly on refresh (F5)\n * http://stackoverflow.com/questions/5690269/disabling-chrome-cache-for-website-development/7000899#answer-11786277\n */\n\n\n function addAttributeInElement(node, elementTarget, separator) {\n let mardownClassesInElementsRegex = new RegExp(separator, 'mg');\n let mardownClassRegex = new RegExp(\"([^\\\"= ]+?)=\\\"([^\\\"=]+?)\\\"\", 'mg');\n let nodeValue = node.nodeValue;\n let matches = mardownClassesInElementsRegex.exec(nodeValue);\n\n if (matches != null) {\n let classes = matches[1];\n nodeValue = nodeValue.substring(0, matches.index) + nodeValue.substring(mardownClassesInElementsRegex.lastIndex);\n node.nodeValue = nodeValue;\n let matchesClass;\n\n while ((matchesClass = mardownClassRegex.exec(classes)) != null) {\n elementTarget.setAttribute(matchesClass[1], matchesClass[2]);\n }\n\n return true;\n }\n\n return false;\n }\n /**\n * Add attributes to the parent element of a text node,\n * or the element of an attribute node.\n */\n\n\n function addAttributes(section, element, previousElement, separatorElementAttributes, separatorSectionAttributes) {\n if (element != null && element.childNodes != undefined && element.childNodes.length > 0) {\n let previousParentElement = element;\n\n for (let i = 0; i < element.childNodes.length; i++) {\n let childElement = element.childNodes[i];\n\n if (i > 0) {\n let j = i - 1;\n\n while (j >= 0) {\n let aPreviousChildElement = element.childNodes[j];\n\n if (typeof aPreviousChildElement.setAttribute == 'function' && aPreviousChildElement.tagName != 'BR') {\n previousParentElement = aPreviousChildElement;\n break;\n }\n\n j = j - 1;\n }\n }\n\n let parentSection = section;\n\n if (childElement.nodeName == 'section') {\n parentSection = childElement;\n previousParentElement = childElement;\n }\n\n if (typeof childElement.setAttribute == 'function' || childElement.nodeType == Node.COMMENT_NODE) {\n addAttributes(parentSection, childElement, previousParentElement, separatorElementAttributes, separatorSectionAttributes);\n }\n }\n }\n\n if (element.nodeType == Node.COMMENT_NODE) {\n if (addAttributeInElement(element, previousElement, separatorElementAttributes) == false) {\n addAttributeInElement(element, section, separatorSectionAttributes);\n }\n }\n }\n /**\n * Converts any current data-markdown slides in the\n * DOM to HTML.\n */\n\n\n function convertSlides() {\n let sections = document.querySelectorAll('[data-markdown]');\n\n for (let i = 0, len = sections.length; i < len; i++) {\n let section = sections[i]; // Only parse the same slide once\n\n if (!section.getAttribute('data-markdown-parsed')) {\n section.setAttribute('data-markdown-parsed', true);\n let notes = section.querySelector('aside.notes');\n let markdown = getMarkdownFromSlide(section);\n section.innerHTML = marked(markdown);\n addAttributes(section, section, null, section.getAttribute('data-element-attributes') || section.parentNode.getAttribute('data-element-attributes') || DEFAULT_ELEMENT_ATTRIBUTES_SEPARATOR, section.getAttribute('data-attributes') || section.parentNode.getAttribute('data-attributes') || DEFAULT_SLIDE_ATTRIBUTES_SEPARATOR); // If there were notes, we need to re-add them after\n // having overwritten the section's HTML\n\n if (notes) {\n section.appendChild(notes);\n }\n }\n }\n } // API\n\n\n return {\n getMarkdownFromSlide: getMarkdownFromSlide,\n createMarkdownSlide: createMarkdownSlide,\n processSlides: processSlides,\n addAttributes: addAttributes,\n convertSlides: convertSlides\n };\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/client/js/util/reveal/plugins/markdown.js.js","sources":["webpack:///./src/client/js/util/reveal/plugins/markdown.js?251e"],"sourcesContent":["/**\n * The reveal.js markdown plugin. Handles parsing of\n * markdown inside of presentations as well as loading\n * of external markdown documents.\n * Referred from The reveal.js markdown plugin.\n * https://github.com/hakimel/reveal.js/blob/master/plugin/markdown/markdown.js\n */\nexport default function( marked ) {\n\n  const DEFAULT_SLIDE_SEPARATOR = '^\\r?\\n---\\r?\\n$',\n    DEFAULT_NOTES_SEPARATOR = 'notes?:',\n    DEFAULT_ELEMENT_ATTRIBUTES_SEPARATOR = '\\\\\\.element\\\\\\s*?(.+?)$',\n    DEFAULT_SLIDE_ATTRIBUTES_SEPARATOR = '\\\\\\.slide:\\\\\\s*?(\\\\\\S.+?)$';\n\n  const SCRIPT_END_PLACEHOLDER = '__SCRIPT_END__';\n\n\n  /**\n   * Retrieves the markdown contents of a slide section\n   * element. Normalizes leading tabs/whitespace.\n   */\n  function getMarkdownFromSlide( section ) {\n\n    // look for a <script> or <textarea data-template> wrapper\n    let template = section.querySelector( '[data-template]' ) || section.querySelector( 'script' );\n\n    // strip leading whitespace so it isn't evaluated as code\n    let text = ( template || section ).textContent;\n\n    // restore script end tags\n    text = text.replace( new RegExp( SCRIPT_END_PLACEHOLDER, 'g' ), '</script>' );\n\n    let leadingWs = text.match( /^\\n?(\\s*)/ )[1].length,\n      leadingTabs = text.match( /^\\n?(\\t*)/ )[1].length;\n\n    if ( leadingTabs > 0 ) {\n      text = text.replace( new RegExp('\\\\n?\\\\t{' + leadingTabs + '}', 'g'), '\\n' );\n    }\n    else if ( leadingWs > 1 ) {\n      text = text.replace( new RegExp('\\\\n? {' + leadingWs + '}', 'g'), '\\n' );\n    }\n\n    return text;\n\n  }\n\n  /**\n   * Given a markdown slide section element, this will\n   * return all arguments that aren't related to markdown\n   * parsing. Used to forward any other user-defined arguments\n   * to the output markdown slide.\n   */\n  function getForwardedAttributes( section ) {\n\n    let attributes = section.attributes;\n    let result = [];\n\n    for ( let i = 0, len = attributes.length; i < len; i++ ) {\n      let name = attributes[i].name,\n        value = attributes[i].value;\n\n      // disregard attributes that are used for markdown loading/parsing\n      if ( /data\\-(markdown|separator|vertical|notes)/gi.test( name ) ) continue;\n\n      if ( value ) {\n        result.push( name + '=\"' + value + '\"' );\n      }\n      else {\n        result.push( name );\n      }\n    }\n\n    return result.join( ' ' );\n\n  }\n\n  /**\n   * Inspects the given options and fills out default\n   * values for what's not defined.\n   */\n  function getSlidifyOptions( options ) {\n\n    options = options || {};\n    options.separator = options.separator || DEFAULT_SLIDE_SEPARATOR;\n    options.notesSeparator = options.notesSeparator || DEFAULT_NOTES_SEPARATOR;\n    options.attributes = options.attributes || '';\n\n    return options;\n\n  }\n\n  /**\n   * Helper function for constructing a markdown slide.\n   */\n  function createMarkdownSlide( content, options ) {\n\n    options = getSlidifyOptions( options );\n\n    let notesMatch = content.split( new RegExp( options.notesSeparator, 'mgi' ) );\n\n    if ( notesMatch.length === 2 ) {\n      content = notesMatch[0] + '<aside class=\"notes\">' + marked(notesMatch[1].trim()) + '</aside>';\n    }\n\n    // prevent script end tags in the content from interfering\n    // with parsing\n    content = content.replace( /<\\/script>/g, SCRIPT_END_PLACEHOLDER );\n\n    return '<script type=\"text/template\">' + content + '</script>';\n\n  }\n\n  /**\n   * Parses a data string into multiple slides based\n   * on the passed in separator arguments.\n   */\n  function slidify( markdown, options ) {\n\n    options = getSlidifyOptions( options );\n\n    let separatorRegex = new RegExp( options.separator + ( options.verticalSeparator ? '|' + options.verticalSeparator : '' ), 'mg' ),\n      horizontalSeparatorRegex = new RegExp( options.separator );\n\n    let matches,\n      lastIndex = 0,\n      isHorizontal,\n      wasHorizontal = true,\n      content,\n      sectionStack = [];\n\n    // iterate until all blocks between separators are stacked up\n    while ( (matches = separatorRegex.exec( markdown )) != null ) {\n      // notes = null;\n\n      // determine direction (horizontal by default)\n      isHorizontal = horizontalSeparatorRegex.test( matches[0] );\n\n      if ( !isHorizontal && wasHorizontal ) {\n        // create vertical stack\n        sectionStack.push( [] );\n      }\n\n      // pluck slide content from markdown input\n      content = markdown.substring( lastIndex, matches.index );\n\n      if ( isHorizontal && wasHorizontal ) {\n        // add to horizontal stack\n        sectionStack.push( content );\n      }\n      else {\n        // add to vertical stack\n        sectionStack[sectionStack.length-1].push( content );\n      }\n\n      lastIndex = separatorRegex.lastIndex;\n      wasHorizontal = isHorizontal;\n    }\n\n    // add the remaining slide\n    ( wasHorizontal ? sectionStack : sectionStack[sectionStack.length-1] ).push( markdown.substring( lastIndex ) );\n\n    let markdownSections = '';\n\n    // flatten the hierarchical stack, and insert <section data-markdown> tags\n    for ( let i = 0, len = sectionStack.length; i < len; i++ ) {\n      // vertical\n      if ( sectionStack[i] instanceof Array ) {\n        markdownSections += '<section '+ options.attributes +'>';\n\n        sectionStack[i].forEach( function( child ) {\n          markdownSections += '<section data-markdown>' + createMarkdownSlide( child, options ) + '</section>';\n        } );\n\n        markdownSections += '</section>';\n      }\n      else {\n        markdownSections += '<section '+ options.attributes +' data-markdown>' + createMarkdownSlide( sectionStack[i], options ) + '</section>';\n      }\n    }\n\n    return markdownSections;\n\n  }\n\n  /**\n   * Parses any current data-markdown slides, splits\n   * multi-slide markdown into separate sections and\n   * handles loading of external markdown.\n   */\n  function processSlides() {\n\n    let sections = document.querySelectorAll( '[data-markdown]'),\n      section;\n\n    for ( let i = 0, len = sections.length; i < len; i++ ) {\n\n      section = sections[i];\n\n      if ( section.getAttribute( 'data-markdown' ).length ) {\n\n        let xhr = new XMLHttpRequest(),\n          url = section.getAttribute( 'data-markdown' );\n\n        let datacharset = section.getAttribute( 'data-charset' );\n\n        // see https://developer.mozilla.org/en-US/docs/Web/API/element.getAttribute#Notes\n        if ( datacharset != null && datacharset != '' ) {\n          xhr.overrideMimeType( 'text/html; charset=' + datacharset );\n        }\n\n        xhr.onreadystatechange = function() {\n          if ( xhr.readyState === 4 ) {\n            // file protocol yields status code 0 (useful for local debug, mobile applications etc.)\n            if ( ( xhr.status >= 200 && xhr.status < 300 ) || xhr.status === 0 ) {\n\n              section.outerHTML = slidify( xhr.responseText, {\n                separator: section.getAttribute( 'data-separator' ),\n                verticalSeparator: section.getAttribute( 'data-separator-vertical' ),\n                notesSeparator: section.getAttribute( 'data-separator-notes' ),\n                attributes: getForwardedAttributes( section )\n              });\n\n            }\n            else {\n\n              section.outerHTML = '<section data-state=\"alert\">' +\n                'ERROR: The attempt to fetch ' + url + ' failed with HTTP status ' + xhr.status + '.' +\n                'Check your browser\\'s JavaScript console for more details.' +\n                '<p>Remember that you need to serve the presentation HTML from a HTTP server.</p>' +\n                '</section>';\n\n            }\n          }\n        };\n\n        xhr.open( 'GET', url, false );\n\n        try {\n          xhr.send();\n        }\n        catch ( e ) {\n          alert( 'Failed to get the Markdown file ' + url + '. Make sure that the presentation and the file are served by a HTTP server and the file can be found there. ' + e );\n        }\n\n      }\n      else if ( section.getAttribute( 'data-separator' ) || section.getAttribute( 'data-separator-vertical' ) || section.getAttribute( 'data-separator-notes' ) ) {\n\n        section.outerHTML = slidify( getMarkdownFromSlide( section ), {\n          separator: section.getAttribute( 'data-separator' ),\n          verticalSeparator: section.getAttribute( 'data-separator-vertical' ),\n          notesSeparator: section.getAttribute( 'data-separator-notes' ),\n          attributes: getForwardedAttributes( section )\n        });\n\n      }\n      else {\n        section.innerHTML = createMarkdownSlide( getMarkdownFromSlide( section ) );\n      }\n    }\n\n  }\n\n  /**\n   * Check if a node value has the attributes pattern.\n   * If yes, extract it and add that value as one or several attributes\n   * the the terget element.\n   *\n   * You need Cache Killer on Chrome to see the effect on any FOM transformation\n   * directly on refresh (F5)\n   * http://stackoverflow.com/questions/5690269/disabling-chrome-cache-for-website-development/7000899#answer-11786277\n   */\n  function addAttributeInElement( node, elementTarget, separator ) {\n\n    let mardownClassesInElementsRegex = new RegExp( separator, 'mg' );\n    let mardownClassRegex = new RegExp( \"([^\\\"= ]+?)=\\\"([^\\\"=]+?)\\\"\", 'mg' );\n    let nodeValue = node.nodeValue;\n    let matches = mardownClassesInElementsRegex.exec( nodeValue );\n    if ( matches != null ) {\n\n      let classes = matches[1];\n      nodeValue = nodeValue.substring( 0, matches.index ) + nodeValue.substring( mardownClassesInElementsRegex.lastIndex );\n      node.nodeValue = nodeValue;\n      let matchesClass;\n      while ( (matchesClass = mardownClassRegex.exec( classes )) != null ) {\n        elementTarget.setAttribute( matchesClass[1], matchesClass[2] );\n      }\n      return true;\n    }\n    return false;\n  }\n\n  /**\n   * Add attributes to the parent element of a text node,\n   * or the element of an attribute node.\n   */\n  function addAttributes( section, element, previousElement, separatorElementAttributes, separatorSectionAttributes ) {\n\n    if ( element != null && element.childNodes != undefined && element.childNodes.length > 0 ) {\n      let previousParentElement = element;\n      for ( let i = 0; i < element.childNodes.length; i++ ) {\n        let childElement = element.childNodes[i];\n        if ( i > 0 ) {\n          let j = i - 1;\n          while ( j >= 0 ) {\n            let aPreviousChildElement = element.childNodes[j];\n            if ( typeof aPreviousChildElement.setAttribute == 'function' && aPreviousChildElement.tagName != 'BR' ) {\n              previousParentElement = aPreviousChildElement;\n              break;\n            }\n            j = j - 1;\n          }\n        }\n        let parentSection = section;\n        if ( childElement.nodeName ==  'section' ) {\n          parentSection = childElement ;\n          previousParentElement = childElement ;\n        }\n        if ( typeof childElement.setAttribute == 'function' || childElement.nodeType == Node.COMMENT_NODE ) {\n          addAttributes( parentSection, childElement, previousParentElement, separatorElementAttributes, separatorSectionAttributes );\n        }\n      }\n    }\n\n    if ( element.nodeType == Node.COMMENT_NODE ) {\n      if ( addAttributeInElement( element, previousElement, separatorElementAttributes ) == false ) {\n        addAttributeInElement( element, section, separatorSectionAttributes );\n      }\n    }\n  }\n\n  /**\n   * Converts any current data-markdown slides in the\n   * DOM to HTML.\n   */\n  function convertSlides() {\n\n    let sections = document.querySelectorAll( '[data-markdown]');\n\n    for ( let i = 0, len = sections.length; i < len; i++ ) {\n\n      let section = sections[i];\n\n      // Only parse the same slide once\n      if ( !section.getAttribute( 'data-markdown-parsed' ) ) {\n\n        section.setAttribute( 'data-markdown-parsed', true );\n\n        let notes = section.querySelector( 'aside.notes' );\n        let markdown = getMarkdownFromSlide( section );\n\n        section.innerHTML = marked( markdown );\n        addAttributes(   section, section, null, section.getAttribute( 'data-element-attributes' ) ||\n                section.parentNode.getAttribute( 'data-element-attributes' ) ||\n                DEFAULT_ELEMENT_ATTRIBUTES_SEPARATOR,\n        section.getAttribute( 'data-attributes' ) ||\n                section.parentNode.getAttribute( 'data-attributes' ) ||\n                DEFAULT_SLIDE_ATTRIBUTES_SEPARATOR);\n\n        // If there were notes, we need to re-add them after\n        // having overwritten the section's HTML\n        if ( notes ) {\n          section.appendChild( notes );\n        }\n\n      }\n\n    }\n\n  }\n\n  // API\n  return {\n    getMarkdownFromSlide: getMarkdownFromSlide,\n    createMarkdownSlide: createMarkdownSlide,\n    processSlides: processSlides,\n    addAttributes: addAttributes,\n    convertSlides: convertSlides\n  };\n}\n"],"mappings":"AAAA;AAAA;;;;;;;AAOA;AAEA;AAAA;AAAA;AAAA;AAKA;AAGA;;;;;AAIA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AAAA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAEA;;;;;;;;AAMA;AAEA;AACA;AACA;AACA;AACA;AAAA;AACA;AAGA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAEA;;;;;;AAIA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AAEA;;;;;AAGA;AAEA;AAEA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AADA;AAEA;AAEA;AAEA;;;;;;AAIA;AAEA;AAEA;AAAA;AAGA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AAOA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAEA;;;;;;;AAKA;AAEA;AAAA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AAAA;AAGA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAJA;AAOA;AAGA;AAMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AAGA;AACA;AACA;AACA;AACA;AAJA;AAOA;AAEA;AACA;AACA;AAEA;AAEA;;;;;;;;;;;AASA;AAEA;AACA;AACA;AACA;AACA;AAAA;AAEA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AAAA;AACA;AAEA;;;;;;AAIA;AAEA;AACA;AACA;AAAA;AACA;AACA;AAAA;AACA;AACA;AAAA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AAAA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;;AAIA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AAEA;AACA;AAEA;AACA;AAQA;AACA;AAAA;AACA;AACA;AAEA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AALA;AAOA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/client/js/util/reveal/plugins/markdown.js\n");
  42. /***/ })
  43. }]);