1 require('codemirror/mode/css/css');
2 require('codemirror/mode/clike/clike');
3 require('codemirror/mode/go/go');
4 require('codemirror/mode/htmlmixed/htmlmixed');
5 require('codemirror/mode/javascript/javascript');
6 require('codemirror/mode/markdown/markdown');
7 require('codemirror/mode/nginx/nginx');
8 require('codemirror/mode/php/php');
9 require('codemirror/mode/powershell/powershell');
10 require('codemirror/mode/python/python');
11 require('codemirror/mode/ruby/ruby');
12 require('codemirror/mode/shell/shell');
13 require('codemirror/mode/sql/sql');
14 require('codemirror/mode/toml/toml');
15 require('codemirror/mode/xml/xml');
16 require('codemirror/mode/yaml/yaml');
18 const CodeMirror = require('codemirror');
31 javascript: 'javascript',
32 json: {name: 'javascript', json: true},
39 powershell: 'powershell',
53 module.exports.highlight = function() {
54 let codeBlocks = document.querySelectorAll('.page-content pre');
55 for (let i = 0; i < codeBlocks.length; i++) {
56 highlightElem(codeBlocks[i]);
60 function highlightElem(elem) {
61 let innerCodeElem = elem.querySelector('code[class^=language-]');
63 if (innerCodeElem !== null) {
64 let langName = innerCodeElem.className.replace('language-', '');
65 if (typeof modeMap[langName] !== 'undefined') mode = modeMap[langName];
67 elem.innerHTML = elem.innerHTML.replace(/<br\s*[\/]?>/gi ,'\n');
68 let content = elem.textContent;
70 CodeMirror(function(elt) {
71 elem.parentNode.replaceChild(elt, elem);
76 theme: 'base16-light',
81 module.exports.highlightElem = highlightElem;
83 module.exports.wysiwygView = function(elem) {
84 let doc = elem.ownerDocument;
85 elem.innerHTML = elem.innerHTML.replace(/<br\s*[\/]?>/gi ,'\n');
86 let content = elem.textContent;
87 let newWrap = doc.createElement('div');
88 let newTextArea = doc.createElement('textarea');
90 newWrap.className = 'CodeMirrorContainer';
91 newTextArea.style.display = 'none';
92 elem.parentNode.replaceChild(newWrap, elem);
94 newWrap.appendChild(newTextArea);
95 newWrap.contentEditable = false;
96 newTextArea.textContent = content;
98 let cm = CodeMirror(function(elt) {
99 newWrap.appendChild(elt);
104 theme: 'base16-light',
113 // module.exports.wysiwygEditor = function(elem) {
114 // let doc = elem.ownerDocument;
115 // let newWrap = doc.createElement('div');
116 // newWrap.className = 'CodeMirrorContainer';
117 // let newTextArea = doc.createElement('textarea');
118 // newTextArea.style.display = 'none';
119 // elem.innerHTML = elem.innerHTML.replace(/<br\s*[\/]?>/gi ,'\n');
120 // let content = elem.textContent;
121 // elem.parentNode.replaceChild(newWrap, elem);
122 // newWrap.appendChild(newTextArea);
123 // let cm = CodeMirror(function(elt) {
124 // newWrap.appendChild(elt);
128 // lineNumbers: true,
129 // theme: 'base16-light',
132 // cm.on('change', event => {
133 // newTextArea.innerText = cm.getValue();
135 // setTimeout(() => {
140 module.exports.markdownEditor = function(elem) {
141 let content = elem.textContent;
143 let cm = CodeMirror(function(elt) {
144 elem.parentNode.insertBefore(elt, elem);
145 elem.style.display = 'none';
150 theme: 'base16-light',