render_namumark.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361
  1. function render_namumark(target) {
  2. function get_today() {
  3. var today_data = new Date();
  4. return '' +
  5. String(today_data.getFullYear()) + '-' +
  6. String(today_data.getMonth() + 1) + '-' +
  7. String(today_data.getDate()) + ' ' +
  8. (today_data.getHours() < 10 ? '0' + String(today_data.getHours()) : String(today_data.getHours())) + ':' +
  9. (today_data.getMinutes() < 10 ? '0' + String(today_data.getMinutes()) : String(today_data.getMinutes())) + ':' +
  10. (today_data.getSeconds() < 10 ? '0' + String(today_data.getSeconds()) : String(today_data.getSeconds())) +
  11. '';
  12. }
  13. var data = '\n' + document.getElementById(target).innerHTML + '\n';
  14. var nowiki_list = [];
  15. var mid_num = 0;
  16. var mid_stack = 0;
  17. var mid_list = [];
  18. var html_number = 0;
  19. data = data.replace(/(?:{{{(?:((?:(?! |{{{|}}}|&lt;).)*) ?)|(}}}))/g, function(all, in_data) {
  20. if(all === '}}}') {
  21. if(mid_list === []) {
  22. return all;
  23. } else {
  24. if(mid_stack > 0) {
  25. mid_stack -= 1;
  26. }
  27. if(mid_stack > 0) {
  28. return all;
  29. } else {
  30. if(mid_num > 0) {
  31. mid_num -= 1;
  32. }
  33. if(mid_list[mid_num] === 'pre') {
  34. var return_data = '</code></pre>';
  35. } else {
  36. var return_data = '</' + mid_list[mid_num] + '>';
  37. }
  38. mid_list.splice(mid_num, 1);
  39. return return_data;
  40. }
  41. }
  42. } else {
  43. if(mid_stack > 0) {
  44. mid_stack += 1;
  45. return all;
  46. } else {
  47. mid_num += 1;
  48. if(in_data.match(/^(#|@|\+|\-)/) && !in_data.match(/^(#|@|\+|\-){2}|(#|@|\+|\-)\\\\/)) {
  49. if(in_data.match(/^((#|@)([0-9a-f-A-F]{3}){1,2})/)) {
  50. mid_list.push('span');
  51. if(in_data.match(/^#/)) {
  52. return '<span style="color: ' + in_data + ';">';
  53. } else {
  54. return '<span style="background: ' + in_data + ';">';
  55. }
  56. } else if(in_data.match(/^((#|@)(\w+))/)) {
  57. mid_list.push('span');
  58. if(in_data.match(/^#/)) {
  59. return '<span style="color: ' + in_data.replace(/^#/, '') + ';">';
  60. } else {
  61. return '<span style="background: ' + in_data.replace(/^@/, '') + ';">';
  62. }
  63. } else if(in_data.match(/^(\+|-)([1-5])/)) {
  64. mid_list.push('span');
  65. var font_size_data = in_data.match(/^(\+|-)([1-5])/);
  66. if(font_size_data[1] == '+') {
  67. font_size_data = String(Number(font_size_data[2]) * 20 + 100);
  68. } else {
  69. font_size_data = String(100 - Number(font_size_data[2]) * 10);
  70. }
  71. return '<span style="font-size: ' + font_size_data + '%;">'
  72. } else if(in_data.match(/#!wiki/i)) {
  73. mid_list.push('div');
  74. if(data.match(/{{{#!wiki style=((?:(?!\n).)+) *\n/i)) {
  75. return '<div id="wiki_div_before">';
  76. } else {
  77. return '<div id="wiki_div">'
  78. }
  79. } else if(in_data.match(/#!syntax/i)) {
  80. mid_list.push('pre');
  81. mid_stack += 1;
  82. return '<pre><code id="syntax_before">';
  83. } else if(in_data.match(/#!folding/i)) {
  84. mid_list.push('div');
  85. return '<div id="folding_before">';
  86. } else if(in_data.match(/#!html/i)) {
  87. mid_list.push('span');
  88. html_number += 1;
  89. return '<span id="html_render_contect_' + String(html_number) + '">';
  90. } else {
  91. mid_list.push('code');
  92. mid_stack += 1;
  93. return '<code>' + in_data;
  94. }
  95. } else {
  96. mid_list.push('code');
  97. mid_stack += 1;
  98. return '<code>' + in_data;
  99. }
  100. }
  101. }
  102. });
  103. console.log(mid_stack);
  104. console.log(mid_num);
  105. console.log(mid_list);
  106. data = data.replace(/<\/div> *\n/ig, '</div>');
  107. data = data.replace(/<div id="folding_before">((?:(?!\n).)+) *\n/ig, function(all, in_data) {
  108. return in_data + ' [+]<div id="folding">';
  109. });
  110. data = data.replace(/<pre><code id="syntax_before">((?:(?!\n).)+) *\n/ig, function(all, in_data) {
  111. return '<pre><code>';
  112. });
  113. data = data.replace(/<div id="wiki_div_before">style=((?:(?!\n).)+) *\n/ig, function(all, in_data) {
  114. return '<div style=' + in_data.replace(/&quot;/g, "\"").replace(/&#039;/g, "'") + ' id="wiki_div">';
  115. });
  116. var nowiki_num = 0;
  117. data = data.replace(/<code>((?:(?!<\/code>).)+)<\/code>/gm, function(all, in_data) {
  118. nowiki_num += 1;
  119. nowiki_list.push(['nowiki_' + String(nowiki_num), in_data]);
  120. return '<span id="nowiki_' + String(nowiki_num) + '"></span>';
  121. });
  122. var math_list = [];
  123. var math_num = 0;
  124. data = data.replace(/\[math\(((?:(?!\)]).)+)\)]/ig, function(all, in_data) {
  125. math_num += 1;
  126. math_list.push(['math_' + String(math_num), in_data]);
  127. return '<span id="math_' + String(math_num) + '"></span>';
  128. });
  129. data = data.replace(/~~((?:(?!~~).)+)~~/g, '<s>$1</s>');
  130. data = data.replace(/--((?:(?!--).)+)--/g, '<s>$1</s>');
  131. data = data.replace(/__((?:(?!__).)+)__/g, '<u>$1</u>');
  132. data = data.replace(/'''((?:(?!''').)+)'''/g, '<b>$1</b>');
  133. data = data.replace(/''((?:(?!'').)+)''/g, '<i>$1</i>');
  134. data = data.replace(/\^\^((?:(?!\^\^).)+)\^\^/g, '<sup>$1</sup>');
  135. data = data.replace(/,,((?:(?!,,).)+),,/g, '<sub>$1</sub>');
  136. data = data.replace(/\[([^(\]]+)\(((?:(?!\)]).)+)\)]/g, function(all, name, in_data) {
  137. if(name.match(/^youtube|kakaotv|nicovideo$/i)) {
  138. var video_code = in_data.match(/^([^,]+)/);
  139. if(video_code) {
  140. video_code = video_code[1];
  141. } else {
  142. video_code = 'test';
  143. }
  144. if(name === 'youtube') {
  145. var video_src = 'https://www.youtube.com/embed/' + video_code
  146. } else if(name === 'kakaotv') {
  147. var video_src = 'https://tv.kakao.com/embed/player/cliplink/' + video_code +'?service=kakao_tv'
  148. } else {
  149. var video_src = 'https://embed.nicovideo.jp/watch/' + video_code
  150. }
  151. var width_data = in_data.match(/, *width=([^,]+)/);
  152. if(width_data) {
  153. width_data = width_data[1];
  154. } else {
  155. width_data = '560';
  156. }
  157. var height_data = in_data.match(/, *height=([^,]+)/);
  158. if(height_data) {
  159. height_data = height_data[1];
  160. } else {
  161. height_data = '315';
  162. }
  163. return '' +
  164. '<iframe ' +
  165. 'width="' + width_data + '" ' +
  166. 'height="' + height_data + '" ' +
  167. 'src="' + video_src + '" ' +
  168. 'allowfullscreen>' +
  169. '</iframe>' +
  170. '';
  171. } else if(name.match(/^ruby$/i)) {
  172. var main_text = in_data.match(/^([^,]+)/);
  173. if(main_text) {
  174. main_text = main_text[1];
  175. } else {
  176. main_text = 'test';
  177. }
  178. var ruby_text = in_data.match(/, *ruby=([^,]+)/);
  179. if(ruby_text) {
  180. ruby_text = ruby_text[1];
  181. } else {
  182. ruby_text = 'test';
  183. }
  184. var color_text = in_data.match(/, *color=([^,]+)/);
  185. if(color_text) {
  186. color_text = 'color:' + color_text[1];
  187. } else {
  188. color_text = '';
  189. }
  190. return '' +
  191. '<ruby>' +
  192. main_text +
  193. '<rp>(</rp>' +
  194. '<rt>' +
  195. '<span style="' + color_text + '">' + ruby_text + '</span>' +
  196. '</rt>' +
  197. '<rp>)</rp>' +
  198. '</ruby>' +
  199. '';
  200. } else if(name.match(/^anchor$/i)) {
  201. return '<span id="' + in_data + '"></span>';
  202. } else {
  203. return all;
  204. }
  205. });
  206. var toc_array = [0, 0, 0, 0, 0, 0];
  207. var before_data = 0;
  208. var toc_data = '<div id="toc"><span id="toc_title">TOC</span>\n\n'
  209. data = data.replace(/\n(={1,6}) ?([^\n]+) (?:={1,6})/g, function(all, num, in_data) {
  210. num = num.length;
  211. if(before_data > num) {
  212. var i = num;
  213. while(1) {
  214. if(i == 6) {
  215. break;
  216. }
  217. toc_array[i] = 0;
  218. i += 1;
  219. }
  220. }
  221. before_data = num;
  222. toc_array[num - 1] += 1;
  223. num = String(num);
  224. var toc_num = (toc_array.join('.') + '.').replace(/0\./g, '');
  225. if(!toc_num.match(/\./)) {
  226. toc_num += '0.';
  227. }
  228. toc_data += '' +
  229. '<span style="margin-left: ' + String(10 * (toc_num.length / 2) - 10) + 'px;">' +
  230. '<a href="#s-' + toc_num.replace(/\.$/, '') + '">' + toc_num + '</a> ' + in_data +
  231. '</span>' +
  232. '\n' +
  233. '';
  234. return '\n<h' + num + ' id="s-' + toc_num.replace(/\.$/, '') + '"><a href="#toc">' + toc_num + '</a> ' + in_data + '</h' + num + '>';
  235. });
  236. toc_data += '</div>';
  237. data = data.replace(/<\/h([0-9])>\n/g, '</h$1>');
  238. data = data.replace(/\[([^\]]+)\]/g, function(all, name) {
  239. if(name.match(/^br$/i)) {
  240. return '\n'
  241. } else if(name.match(/^목차$/i)) {
  242. return toc_data;
  243. } else if(name.match(/^date|datetime$/i)) {
  244. return get_today();
  245. } else {
  246. return all;
  247. }
  248. });
  249. var ref_num = 0;
  250. var ref_data = '<hr><ul id="footnote_data">';
  251. data = data.replace(/(?:\[\* ([^\]]+)\]|\[(?:각주|footnote)])/g, function(all, in_data) {
  252. if(all.match(/^\[(?:각주|footnote)]$/i)) {
  253. var new_ref_data = ref_data;
  254. ref_data = '<hr><ul id="footnote_data">';
  255. return new_ref_data + '</ul>';
  256. } else {
  257. ref_num += 1;
  258. ref_data += '' +
  259. '<li>' +
  260. '(' + String(ref_num) + ') ' + in_data +
  261. '</li>' +
  262. ''
  263. return '' +
  264. '<sup>' +
  265. '<a href="#" title="' + in_data.replace(/<([^>]*)>/g, '') + '">' +
  266. '(' + String(ref_num) + ')' +
  267. '</a>' +
  268. '</sup>' +
  269. '';
  270. }
  271. });
  272. data += ref_data;
  273. i = 0;
  274. while(1) {
  275. if(nowiki_list[i]) {
  276. data = data.replace('<span id="' + nowiki_list[i][0] + '"></span>', '<code>' + nowiki_list[i][1] + '</code>');
  277. i += 1;
  278. } else {
  279. break;
  280. }
  281. }
  282. data = data.replace(/^(\n| )+/g, '');
  283. data = data.replace(/(\n| )+$/g, '');
  284. data = data.replace(/\n/g, '<br>');
  285. data = data.replace(/&amp;/g, '&');
  286. document.getElementById(target).innerHTML = data;
  287. var i = 0;
  288. while(1) {
  289. if(math_list[i]) {
  290. console.log(i);
  291. try {
  292. katex.render(math_list[i][1], document.getElementById(math_list[i][0]));
  293. } catch {
  294. try {
  295. document.getElementById(math_list[i][0]).innerHTML = '<span style="color: red;">' + math_list[i][1] + '</span>';
  296. } catch {}
  297. }
  298. i += 1;
  299. } else {
  300. break;
  301. }
  302. }
  303. render_html("html_render_contect");
  304. }