summaryrefslogtreecommitdiff
path: root/public/js/index.js
diff options
context:
space:
mode:
authorWu Cheng-Han2016-07-30 11:07:08 +0800
committerWu Cheng-Han2016-07-30 11:07:08 +0800
commit8791447ef918eb38736a94e8e126c17269f3b683 (patch)
tree9546614bf4f595ee5a93ed474d60cb783a7519a5 /public/js/index.js
parent0f4f270193261bf9d0e8fd8729b2d863a35ee5f0 (diff)
Update to support slide preview in both mode
Diffstat (limited to 'public/js/index.js')
-rw-r--r--public/js/index.js45
1 files changed, 33 insertions, 12 deletions
diff --git a/public/js/index.js b/public/js/index.js
index 5251541c..6a1c6e76 100644
--- a/public/js/index.js
+++ b/public/js/index.js
@@ -2914,18 +2914,39 @@ function updateViewInner() {
var lastMeta = md.meta;
md.meta = {};
var rendered = md.render(value);
- // only render again when meta changed
- if (JSON.stringify(md.meta) != JSON.stringify(lastMeta)) {
- parseMeta(md, ui.area.codemirror, ui.area.markdown, $('#toc'), $('#toc-affix'));
- rendered = md.render(value);
- }
- // prevent XSS
- rendered = preventXSS(rendered);
- var result = postProcess(rendered).children().toArray();
- partialUpdate(result, lastResult, ui.area.markdown.children().toArray());
- if (result && lastResult && result.length != lastResult.length)
- updateDataAttrs(result, ui.area.markdown.children().toArray());
- lastResult = $(result).clone();
+ if (md.meta.type && md.meta.type === 'slide') {
+ var slideOptions = {
+ separator: '^(\r\n?|\n)---(\r\n?|\n)$',
+ verticalSeparator: '^(\r\n?|\n)----(\r\n?|\n)$'
+ };
+ var slides = RevealMarkdown.slidify(editor.getValue(), slideOptions);
+ ui.area.markdown.html(slides);
+ RevealMarkdown.initialize();
+ // prevent XSS
+ ui.area.markdown.html(preventXSS(ui.area.markdown.html()));
+ ui.area.markdown.addClass('slides');
+ syncscroll = false;
+ checkSyncToggle();
+ } else {
+ if (lastMeta.type && lastMeta.type === 'slide') {
+ refreshView();
+ ui.area.markdown.removeClass('slides');
+ syncscroll = true;
+ checkSyncToggle();
+ }
+ // only render again when meta changed
+ if (JSON.stringify(md.meta) != JSON.stringify(lastMeta)) {
+ parseMeta(md, ui.area.codemirror, ui.area.markdown, $('#toc'), $('#toc-affix'));
+ rendered = md.render(value);
+ }
+ // prevent XSS
+ rendered = preventXSS(rendered);
+ var result = postProcess(rendered).children().toArray();
+ partialUpdate(result, lastResult, ui.area.markdown.children().toArray());
+ if (result && lastResult && result.length != lastResult.length)
+ updateDataAttrs(result, ui.area.markdown.children().toArray());
+ lastResult = $(result).clone();
+ }
finishView(ui.area.markdown);
autoLinkify(ui.area.markdown);
deduplicatedHeaderId(ui.area.markdown);