define([ 'jquery', '/bower_components/marked/marked.min.js', '/bower_components/diff-dom/diffDOM.js' ],function ($, Marked) { var DiffDOM = window.diffDOM; var renderer = new Marked.Renderer(); var checkedTaskItemPtn = /^\s*\[x\]\s*/; var uncheckedTaskItemPtn = /^\s*\[ \]\s*/; renderer.listitem = function (text, level) { var isCheckedTaskItem = checkedTaskItemPtn.test(text); var isUncheckedTaskItem = uncheckedTaskItemPtn.test(text); if (isCheckedTaskItem) { text = text.replace(checkedTaskItemPtn, ' ') + '\n'; } if (isUncheckedTaskItem) { text = text.replace(uncheckedTaskItemPtn, ' ') + '\n'; } var cls = (isCheckedTaskItem || isUncheckedTaskItem) ? ' class="todo-list-item"' : ''; return '' + text + '\n'; }; Marked.setOptions({ renderer: renderer }); var truthy = function (x) { return x; }; var Slide = { index: 0, lastIndex: 0, content: [], changeHandlers: [], }; var APP; var ifrw; var $modal; var $content; var $pad; var placeholder; var options; var separator = '
'; var separatorReg = /
/g; var slideClass = 'slide-frame'; Slide.onChange = function (f) { if (typeof(f) === 'function') { Slide.changeHandlers.push(f); } }; var getNumberOfSlides = Slide.getNumberOfSlides = function () { return $content.find('.' + slideClass).length; }; var change = function (oldIndex, newIndex) { if (Slide.changeHandlers.length) { Slide.changeHandlers.some(function (f, i) { // HERE f(oldIndex, newIndex, getNumberOfSlides()); }); } }; var forbiddenTags = Slide.forbiddenTags = [ 'SCRIPT', 'IFRAME', 'OBJECT', 'APPLET', 'VIDEO', 'AUDIO', ]; var unsafeTag = function (info) { if (['addAttribute', 'modifyAttribute'].indexOf(info.diff.action) !== -1) { if (/^on/.test(info.diff.name)) { console.log("Rejecting forbidden element attribute with name", info.diff.name); return true; } } if (['addElement', 'replaceElement'].indexOf(info.diff.action) !== -1) { var msg = "Rejecting forbidden tag of type (%s)"; if (info.diff.element && forbiddenTags.indexOf(info.diff.element.nodeName) !== -1) { console.log(msg, info.diff.element.nodeName); return true; } else if (info.diff.newValue && forbiddenTags.indexOf(info.diff.newValue.nodeName) !== -1) { console.log("Replacing restricted element type (%s) with PRE", info.diff.newValue.nodeName); info.diff.newValue.nodeName = 'PRE'; } } }; var domFromHTML = Slide.domFromHTML = function (html) { return new DOMParser().parseFromString(html, "text/html"); }; var DD = new DiffDOM({ preDiffApply: function (info) { if (unsafeTag(info)) { return true; } } }); var makeDiff = function (A, B) { var Err; var Els = [A, B].map(function (frag) { if (typeof(frag) === 'object') { if (!frag || (frag && !frag.body)) { Err = "No body"; return; } var els = frag.body.querySelectorAll('#content'); if (els.length) { return els[0]; } } Err = 'No candidate found'; }); if (Err) { return Err; } var patch = DD.diff(Els[0], Els[1]); return patch; }; var slice = function (coll) { return Array.prototype.slice.call(coll); }; /* remove listeners from the DOM */ var removeListeners = function (root) { slice(root.attributes).map(function (attr) { if (/^on/.test(attr.name)) { root.attributes.removeNamedItem(attr.name); } }); // all the way down slice(root.children).forEach(removeListeners); }; var updateFontSize = Slide.updateFontSize = function() { // 20vh // 20 * 16 / 9vw if ($(window).width() > 16/9*$(window).height()) { $content.css('font-size', '20vh'); // $print.css('font-size', '20vh'); return; } $content.css('font-size', (20*9/16)+'vw'); // $print.css('font-size', (20*9/16)+'vw'); }; var fixCSS = function (css) { var append = '.cp #print .slide-frame '; var append2 = '.cp div#modal #content .slide-frame '; return css.replace(/(\n*)([^\n}]+)\s*\{/g, '$1' + append + '$2,' + append2 + '$2 {'); }; var draw = Slide.draw = function (i) { i = i || 0; if (typeof(Slide.content) !== 'string') { return; } var c = Slide.content; var m = ''+Marked(c).replace(separatorReg, '')+''; var Dom = domFromHTML('
' + m + '
'); removeListeners(Dom.body); var patch = makeDiff(domFromHTML($content[0].outerHTML), Dom); if (typeof(patch) === 'string') { $content.html(m); } else { DD.apply($content[0], patch); } var length = getNumberOfSlides(); $modal.find('style.slideStyle').remove(); if (options.style && Slide.shown) { $modal.prepend($('