2015-05-15 04:58:13 +00:00
|
|
|
var markdown = $(".markdown-body");
|
2015-07-01 16:10:20 +00:00
|
|
|
var text = $('<textarea/>').html(markdown.html()).text();
|
2016-01-12 14:01:42 +00:00
|
|
|
md.meta = {};
|
|
|
|
md.render(text); //only for get meta
|
|
|
|
parseMeta(md, markdown, $('#toc'), $('#toc-affix'));
|
2016-02-11 09:45:13 +00:00
|
|
|
var rendered = md.render(text);
|
|
|
|
rendered = preventXSS(rendered);
|
|
|
|
var result = postProcess(rendered);
|
2015-07-01 16:10:20 +00:00
|
|
|
markdown.html(result.html());
|
|
|
|
$(document.body).show();
|
2015-05-15 04:58:13 +00:00
|
|
|
finishView(markdown);
|
|
|
|
autoLinkify(markdown);
|
2015-09-25 06:27:23 +00:00
|
|
|
deduplicatedHeaderId(markdown);
|
2015-12-20 17:28:54 +00:00
|
|
|
renderTOC(markdown);
|
2015-07-01 16:10:20 +00:00
|
|
|
generateToc('toc');
|
|
|
|
generateToc('toc-affix');
|
|
|
|
smoothHashScroll();
|
2016-01-12 14:01:42 +00:00
|
|
|
lastchangetime = lastchangeui.time.text();
|
2015-07-01 16:10:20 +00:00
|
|
|
updateLastChange();
|
|
|
|
var url = window.location.pathname;
|
|
|
|
$('.ui-edit').attr('href', url + '/edit');
|
|
|
|
var toc = $('.ui-toc');
|
|
|
|
var tocAffix = $('.ui-affix-toc');
|
|
|
|
var tocDropdown = $('.ui-toc-dropdown');
|
|
|
|
//toc
|
|
|
|
tocDropdown.click(function (e) {
|
|
|
|
e.stopPropagation();
|
|
|
|
});
|
|
|
|
|
|
|
|
var enoughForAffixToc = true;
|
|
|
|
|
|
|
|
function generateScrollspy() {
|
|
|
|
$(document.body).scrollspy({
|
|
|
|
target: ''
|
|
|
|
});
|
|
|
|
$(document.body).scrollspy('refresh');
|
|
|
|
if (enoughForAffixToc) {
|
|
|
|
toc.hide();
|
|
|
|
tocAffix.show();
|
|
|
|
} else {
|
|
|
|
tocAffix.hide();
|
|
|
|
toc.show();
|
|
|
|
}
|
|
|
|
$(document.body).scroll();
|
|
|
|
}
|
|
|
|
|
|
|
|
function windowResize() {
|
|
|
|
//toc right
|
|
|
|
var paddingRight = parseFloat(markdown.css('padding-right'));
|
|
|
|
var right = ($(window).width() - (markdown.offset().left + markdown.outerWidth() - paddingRight));
|
|
|
|
toc.css('right', right + 'px');
|
|
|
|
//affix toc left
|
|
|
|
var newbool;
|
|
|
|
var rightMargin = (markdown.parent().outerWidth() - markdown.outerWidth()) / 2;
|
|
|
|
//for ipad or wider device
|
|
|
|
if (rightMargin >= 133) {
|
|
|
|
newbool = true;
|
|
|
|
var affixLeftMargin = (tocAffix.outerWidth() - tocAffix.width()) / 2;
|
|
|
|
var left = markdown.offset().left + markdown.outerWidth() - affixLeftMargin;
|
|
|
|
tocAffix.css('left', left + 'px');
|
|
|
|
} else {
|
|
|
|
newbool = false;
|
|
|
|
}
|
|
|
|
if (newbool != enoughForAffixToc) {
|
|
|
|
enoughForAffixToc = newbool;
|
|
|
|
generateScrollspy();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$(window).resize(function () {
|
|
|
|
windowResize();
|
|
|
|
});
|
|
|
|
$(document).ready(function () {
|
|
|
|
windowResize();
|
|
|
|
generateScrollspy();
|
2016-01-12 14:01:42 +00:00
|
|
|
//tooltip
|
|
|
|
$('[data-toggle="tooltip"]').tooltip();
|
2015-07-01 16:10:20 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
function scrollToTop() {
|
2015-09-25 06:08:02 +00:00
|
|
|
$('body, html').stop(true, true).animate({
|
2015-07-01 16:10:20 +00:00
|
|
|
scrollTop: 0
|
|
|
|
}, 100, "linear");
|
|
|
|
}
|
|
|
|
|
|
|
|
function scrollToBottom() {
|
2015-09-25 06:08:02 +00:00
|
|
|
$('body, html').stop(true, true).animate({
|
2015-07-01 16:10:20 +00:00
|
|
|
scrollTop: $(document.body)[0].scrollHeight
|
|
|
|
}, 100, "linear");
|
|
|
|
}
|