(window["webpackJsonp"] = window["webpackJsonp"] || []).push([[0],{ /***/ "./node_modules/reveal.js/lib/js/classList.js": /*!****************************************************!*\ !*** ./node_modules/reveal.js/lib/js/classList.js ***! \****************************************************/ /*! no static exports found */ /***/ (function(module, exports) { 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 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"); /***/ }), /***/ "./src/client/js/util/reveal/plugins/growi-renderer.js": /*!*************************************************************!*\ !*** ./src/client/js/util/reveal/plugins/growi-renderer.js ***! \*************************************************************/ /*! no static exports found */ /***/ (function(module, exports, __webpack_require__) { 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"); /***/ }), /***/ "./src/client/js/util/reveal/plugins/markdown.js": /*!*******************************************************!*\ !*** ./src/client/js/util/reveal/plugins/markdown.js ***! \*******************************************************/ /*! exports provided: default */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; 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 ');\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] + '';\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 '';\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
tags\n\n for (let i = 0, len = sectionStack.length; i < len; i++) {\n // vertical\n if (sectionStack[i] instanceof Array) {\n markdownSections += '
';\n sectionStack[i].forEach(function (child) {\n markdownSections += '
' + createMarkdownSlide(child, options) + '
';\n });\n markdownSections += '
';\n } else {\n markdownSections += '
' + createMarkdownSlide(sectionStack[i], options) + '
';\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 = '
' + 'ERROR: The attempt to fetch ' + url + ' failed with HTTP status ' + xhr.status + '.' + 'Check your browser\\'s JavaScript console for more details.' + '

Remember that you need to serve the presentation HTML from a HTTP server.

' + '
';\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"); /***/ }) }]);