summaryrefslogtreecommitdiff
path: root/public/js
diff options
context:
space:
mode:
authorWu Cheng-Han2015-09-25 19:09:43 +0800
committerWu Cheng-Han2015-09-25 19:09:43 +0800
commit5f82df7eb2f37b06684e380fd261b8eb9ea2d50b (patch)
treebdffc648391cbce4f7f9a3b235687e2a8593627f /public/js
parent60414febee5fd14743fd80cad9d681c3027272dd (diff)
Added support of export to HTML, and changed the navbar menu for consistency
Diffstat (limited to '')
-rw-r--r--public/js/extra.js62
-rw-r--r--public/js/index.js13
2 files changed, 71 insertions, 4 deletions
diff --git a/public/js/extra.js b/public/js/extra.js
index fd150bea..3a0f006e 100644
--- a/public/js/extra.js
+++ b/public/js/extra.js
@@ -212,8 +212,70 @@ function postProcess(code) {
result.find('a:not([target])').attr('target', '_blank');
return result;
}
+
+//extract markdown body to html and compile to template
+function exportToHTML(view) {
+ var title = renderTitle(ui.area.markdown);
+ var filename = renderFilename(ui.area.markdown) + '.html';
+ var src = view.clone();
+ var eles = src.find('*');
+ //remove syncscroll parts
+ eles.removeClass('part');
+ src.find('*[class=""]').removeAttr('class');
+ eles.removeAttr('data-startline data-endline');
+ eles.find("a[href^='#'][smoothhashscroll]").removeAttr('smoothhashscroll');
+ //remove gist content
+ src.find("code[data-gist-id]").children().remove();
+ //disable todo list
+ src.find("input.task-list-item-checkbox").attr('disabled', '');
+ //replace emoji image path
+ src.find("img.emoji").each(function (key, value) {
+ var name = $(value).attr('alt');
+ name = name.substr(1);
+ name = name.slice(0, name.length - 1);
+ $(value).attr('src', 'https://www.tortue.me/emoji/' + name + '.png');
+ });
+ //replace video to iframe
+ src.find("div[videoid]").each(function (key, value) {
+ var id = $(value).attr('videoid');
+ var style = $(value).attr('style');
+ var url = null;
+ if ($(value).hasClass('youtube')) {
+ url = 'https://www.youtube.com/embed/';
+ } else if ($(value).hasClass('vimeo')) {
+ url = 'https://player.vimeo.com/video/';
}
+ if (url) {
+ var iframe = $('<iframe frameborder="0" webkitallowfullscreen mozallowfullscreen allowfullscreen></iframe>');
+ iframe.attr('src', url + id);
+ iframe.attr('style', style);
+ $(value).html(iframe);
}
+ });
+ //generate toc
+ var toc = $('#toc').clone();
+ toc.find('*').removeClass('active');
+ var tocAffix = $('#toc-affix').clone();
+ tocAffix.find('*').removeClass('active');
+ //generate html via template
+ $.get('/css/html.min.css', function (css) {
+ $.get('/views/html.hbs', function (data) {
+ var template = Handlebars.compile(data);
+ var context = {
+ title: title,
+ css: css,
+ html: src[0].outerHTML,
+ toc: toc.html(),
+ 'toc-affix': tocAffix.html()
+ };
+ var html = template(context);
+ // console.log(html);
+ var blob = new Blob([html], {
+ type: "text/html;charset=utf-8"
+ });
+ saveAs(blob, filename);
+ });
+ });
}
//jQuery sortByDepth
diff --git a/public/js/index.js b/public/js/index.js
index 8e1bd41d..8bfecede 100644
--- a/public/js/index.js
+++ b/public/js/index.js
@@ -285,9 +285,10 @@ var ui = {
new: $(".ui-new"),
publish: $(".ui-publish"),
download: {
- markdown: $(".ui-download-markdown")
+ markdown: $(".ui-download-markdown"),
+ html: $(".ui-download-html")
},
- save: {
+ export: {
dropbox: $(".ui-save-dropbox")
},
import: {
@@ -801,8 +802,12 @@ ui.toolbar.download.markdown.click(function () {
});
saveAs(blob, filename);
});
-//save to dropbox
-ui.toolbar.save.dropbox.click(function () {
+//html
+ui.toolbar.download.html.click(function () {
+ exportToHTML(ui.area.markdown);
+});
+//export to dropbox
+ui.toolbar.export.dropbox.click(function () {
var filename = renderFilename(ui.area.markdown) + '.md';
var options = {
files: [