trilium/src/public/javascripts/dialogs/note_source.js

60 lines
1.3 KiB
JavaScript
Raw Normal View History

2017-12-27 07:15:29 +08:00
"use strict";
import noteEditor from '../note_editor.js';
2017-12-27 07:15:29 +08:00
const $showDialogButton = $("#show-source-button");
const $dialog = $("#note-source-dialog");
const $noteSource = $("#note-source");
2017-12-27 07:15:29 +08:00
function showDialog() {
glob.activeDialog = $dialog;
2017-12-27 07:15:29 +08:00
$dialog.dialog({
modal: true,
width: 800,
height: 500
});
2017-12-27 07:15:29 +08:00
const noteText = noteEditor.getCurrentNote().detail.content;
2017-12-27 07:15:29 +08:00
$noteSource.text(formatHtml(noteText));
}
2017-12-27 07:15:29 +08:00
function formatHtml(str) {
const div = document.createElement('div');
div.innerHTML = str.trim();
2017-12-27 07:15:29 +08:00
return formatNode(div, 0).innerHTML.trim();
}
2017-12-27 07:15:29 +08:00
function formatNode(node, level) {
const indentBefore = new Array(level++ + 1).join(' ');
const indentAfter = new Array(level - 1).join(' ');
let textNode;
2017-12-27 07:15:29 +08:00
for (let i = 0; i < node.children.length; i++) {
textNode = document.createTextNode('\n' + indentBefore);
node.insertBefore(textNode, node.children[i]);
2017-12-27 07:15:29 +08:00
formatNode(node.children[i], level);
2017-12-27 07:15:29 +08:00
if (node.lastElementChild === node.children[i]) {
textNode = document.createTextNode('\n' + indentAfter);
node.appendChild(textNode);
}
2017-12-27 07:15:29 +08:00
}
return node;
}
2017-12-27 07:15:29 +08:00
$(document).bind('keydown', 'ctrl+u', e => {
showDialog();
e.preventDefault();
});
2017-12-27 07:15:29 +08:00
$showDialogButton.click(showDialog);
export default {
showDialog
};