load_onmark_render.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298
  1. // Tool
  2. function do_url_change(data) {
  3. return encodeURIComponent(data);
  4. }
  5. function do_return_date() {
  6. var today_data = new Date();
  7. return '' +
  8. String(today_data.getFullYear()) + '-' +
  9. ((today_data.getMonth() + 1) < 10 ? '0' : '') + String(today_data.getMonth() + 1) + '-' +
  10. (today_data.getDate() < 10 ? '0' : '') + String(today_data.getDate()) + ' ' +
  11. (today_data.getHours() < 10 ? '0' : '') + String(today_data.getHours()) + ':' +
  12. (today_data.getMinutes() < 10 ? '0' : '') + String(today_data.getMinutes()) + ':' +
  13. (today_data.getSeconds() < 10 ? '0' : '') + String(today_data.getSeconds()) +
  14. '';
  15. }
  16. // Sub
  17. function do_onmark_text_render(data) {
  18. data = data.replace(/'''((?:(?!''').)+)'''/g, '<b>$1</b>');
  19. data = data.replace(/''((?:(?!'').)+)''/g, '<i>$1</i>');
  20. data = data.replace(/__((?:(?!__).)+)__/g, '<u>$1</u>');
  21. data = data.replace(/\^\^((?:(?!\^\^).)+)\^\^/g, '<sup>$1</sup>');
  22. data = data.replace(/,,((?:(?!,,).)+),,/g, '<sub>$1</sub>');
  23. data = data.replace(/--((?:(?!--).)+)--/g, '<s>$1</s>');
  24. data = data.replace(/~~((?:(?!~~).)+)~~/g, '<s>$1</s>');
  25. return data;
  26. }
  27. function do_onmark_heading_render(data) {
  28. var heading_re = /<br>(={1,6}) ?([^=]+) ?={1,6}<br>/;
  29. var heading_level_all = [0, 0, 0, 0, 0, 0];
  30. var toc_data = '<div id="toc"><div id="toc_title">TOC</div><br>';
  31. while(1) {
  32. var heading_data = data.match(heading_re);
  33. if(!heading_data) {
  34. break;
  35. }
  36. var heading_level = heading_data[1].length;
  37. heading_level_all[heading_level - 1] += 1;
  38. var i = 6;
  39. while(i > heading_level - 1) {
  40. heading_level_all[i] = 0;
  41. i -= 1;
  42. }
  43. heading_level = String(heading_level);
  44. var heading_level_string = '';
  45. i = 0;
  46. while(i < 6) {
  47. if(heading_level_all[i] !== 0) {
  48. heading_level_string += String(heading_level_all[i]) + '.';
  49. }
  50. i += 1;
  51. }
  52. var heading_level_string_no_end = heading_level_string.replace(/\.$/, '');
  53. toc_data += '' +
  54. '<span style="margin-left: ' + String((heading_level_string.match(/\./g).length - 1) * 10) + 'px;">' +
  55. '<a href="#s-' + heading_level_string_no_end + '">' +
  56. heading_level_string + ' ' +
  57. '</a>' + heading_data[2] +
  58. '</span>' +
  59. '<br>' +
  60. ''
  61. data = data.replace(heading_re,
  62. '<h' + heading_level + ' id="s-' + heading_level_string_no_end + '">' +
  63. '<a href="#toc">' + heading_level_string + '</a> ' + heading_data[2] +
  64. '</h' + heading_level + '>' +
  65. '<br>'
  66. );
  67. }
  68. data = data.replace(/(<\/h[0-9]>)<br>/g, '$1');
  69. data = data.replace(/\[(?:toc|목차)\]/g, toc_data + '</div>');
  70. return data;
  71. }
  72. function do_onmark_link_render(data, data_js, name_doc, name_include) {
  73. var link_num = 0;
  74. data = data.replace(/\[\[(((?!\]\]).)+)\]\]/g, function(x, x_1) {
  75. var link_split = x_1.split('|');
  76. var link_real = link_split[0];
  77. var link_out = link_split[1] ? link_split[1] : link_split[0];
  78. link_num += 1;
  79. var link_num_str = String(link_num - 1);
  80. if(link_real.match(/^http(s)?:\/\//)) {
  81. var i = 0;
  82. while(i < 2) {
  83. if(i === 0) {
  84. var var_link_type = 'href';
  85. } else {
  86. var var_link_type = 'title';
  87. }
  88. data_js += '' +
  89. 'document.getElementsByName("' + name_include + 'set_link_' + link_num_str + '")[0].' + var_link_type + ' = ' +
  90. '"' + link_real.replace(/"/g, '\\"') + '";' +
  91. '\n' +
  92. '';
  93. i += 1;
  94. }
  95. return '<a id="out_link" ' +
  96. 'name="' + name_include + 'set_link_' + link_num_str + '" ' +
  97. 'title=""' +
  98. 'href="">' + link_out + '</a>';
  99. } else {
  100. var i = 0;
  101. while(i < 2) {
  102. if(i === 0) {
  103. var var_link_type = 'href';
  104. var var_link_data = '/w/' + do_url_change(link_real);
  105. } else {
  106. var var_link_type = 'title';
  107. var var_link_data = link_real.replace(/"/g, '\\"');
  108. }
  109. data_js += '' +
  110. 'document.getElementsByName("' + name_include + 'set_link_' + link_num_str + '")[0].' + var_link_type + ' = ' +
  111. '"' + var_link_data + '";' +
  112. '\n' +
  113. '';
  114. i += 1;
  115. }
  116. return '<a class="' + name_include + 'link_finder" ' +
  117. 'name="' + name_include + 'set_link_' + link_num_str + '" ' +
  118. 'title="" ' +
  119. 'href="">' + link_out + '</a>';
  120. }
  121. });
  122. return [data, data_js];
  123. }
  124. function do_onmark_footnote_render(data, name_include) {
  125. var footnote_end_data = '';
  126. var footnote_all_data = {};
  127. var footnote_re = /(?:\[\*([^ \]]*)(?: ((?:(?!\n|\]).)+))?\]|\[(footnote|각주)\])/;
  128. var i = 1;
  129. while(1) {
  130. var footnote_data = data.match(footnote_re);
  131. if(!footnote_data) {
  132. break;
  133. }
  134. if(!footnote_data[3]) {
  135. if(!footnote_data[2]) {
  136. var footnote_line_data = '';
  137. } else {
  138. var footnote_line_data = footnote_data[2];
  139. }
  140. if(!footnote_data[1]) {
  141. var footnote_name = String(i);
  142. } else {
  143. var footnote_name = footnote_data[1];
  144. }
  145. if(!footnote_all_data[footnote_name]) {
  146. footnote_all_data[footnote_name] = footnote_line_data;
  147. }
  148. footnote_line_data = footnote_all_data[footnote_name];
  149. footnote_end_data += '' +
  150. '<li>' +
  151. '<a href="javascript:do_open_foot(\'' + name_include + 'fn-' + String(i) + '\', 1);" ' +
  152. 'id="' + name_include + 'cfn-' + String(i) + '">' +
  153. '(' + footnote_name + ')' +
  154. '</a> <span id="' + name_include + 'fn-' + String(i) + '">' + footnote_line_data + '</span>' +
  155. '</li>' +
  156. '';
  157. data = data.replace(footnote_re, '' +
  158. '<sup>' +
  159. '<a href="javascript:do_open_foot(\'' + name_include + 'fn-' + String(i) + '\', 0);" ' +
  160. 'id="' + name_include + 'rfn-' + String(i) + '">' +
  161. '(' + footnote_name + ')' +
  162. '</a>' +
  163. '</sup><span id="' + name_include + 'dfn-' + String(i) + '"></span>' +
  164. '');
  165. i += 1;
  166. } else {
  167. if(footnote_end_data !== '') {
  168. data = data.replace(footnote_re, '<ul id="footnote_data">' + footnote_end_data + '</ul>');
  169. }
  170. footnote_end_data = '';
  171. }
  172. }
  173. if(footnote_end_data !== '') {
  174. data += '<ul id="footnote_data">' + footnote_end_data + '</ul>';
  175. }
  176. return data;
  177. }
  178. function do_onmark_macro_render(data) {
  179. data = data.replace(/\[([^[\](]+)\(((?:(?!\)\]).)+)\)\]/g, function(x, x_1, x_2) {
  180. x_1 = x_1.toLowerCase();
  181. console.log(x_1);
  182. if(x_1 === 'youtube' || x_1 === 'kakaotv' || x_1 === 'nicovideo') {
  183. var video_code = x_2.match(/^([^,]+)/);
  184. video_code = video_code ? video_code[1] : '';
  185. var video_width = x_2.match(/,(?: *)width=([0-9]+)/);
  186. video_width = video_width ? (video_width[1] + 'px') : '640px';
  187. var video_height = x_2.match(/,(?: *)height=([0-9]+)/);
  188. video_height = video_height ? (video_height[1] + 'px') : '360px';
  189. if(x_1 === 'youtube') {
  190. var video_start = x_2.match(/,(?: *)start=([0-9]+)/);
  191. video_start = video_start ? ('?' + video_start[1]) : '';
  192. video_code = video_code.replace(/^https:\/\/www\.youtube\.com\/watch\?v=/, '');
  193. video_code = video_code.replace(/^https:\/\/youtu\.be\//, '');
  194. var video_src = 'https://www.youtube.com/embed/' + video_code + video_start
  195. } else if(x_1 === 'kakaotv') {
  196. video_code = video_code.replace(/^https:\/\/tv\.kakao\.com\/channel\/9262\/cliplink\//, '');
  197. video_code = video_code.replace(/^http:\/\/tv\.kakao\.com\/v\//, '');
  198. var video_src = 'https://tv.kakao.com/embed/player/cliplink/' + video_code +'?service=kakao_tv'
  199. } else {
  200. var video_src = 'https://embed.nicovideo.jp/watch/' + video_code
  201. }
  202. return '<iframe style="width: ' + video_width + '; height: ' + video_height + ';" src="' + video_src + '" frameborder="0" allowfullscreen></iframe>';
  203. } else if(x_1 === 'anchor') {
  204. return '<span id="' + x_2 + '"></span>';
  205. } else {
  206. return '<macro_start>' + x_1 + '(' + x_2 + ')<macro_end>';
  207. }
  208. });
  209. data = data.replace(/\[([^[*()\]]+)\]/g, function(x, x_1) {
  210. x_1 = x_1.toLowerCase();
  211. if(x_1 === 'date') {
  212. return do_return_date();
  213. } else if(x_1 === 'clearfix') {
  214. return '<div style="clear:both"></div>';
  215. } else if(x_1 === 'br') {
  216. return '<br>';
  217. } else {
  218. return '<macro_start>' + x_1 + '<macro_end>';
  219. }
  220. });
  221. data = data.replace(/<macro_start>/g, '[');
  222. data = data.replace(/<macro_end>/g, ']');
  223. return data;
  224. }
  225. // Main
  226. function do_onmark_render(name_id, name_include = '', name_doc = '') {
  227. var data = document.getElementById(name_id).innerHTML;
  228. var data_js = '';
  229. data = '<br>' + data.replace(/\n/g, '<br>') + '<br>';
  230. data = do_onmark_text_render(data);
  231. data = do_onmark_heading_render(data);
  232. var var_data = do_onmark_link_render(data, data_js, name_doc, name_include);
  233. data = var_data[0];
  234. data_js = var_data[1];
  235. data = do_onmark_macro_render(data);
  236. data = do_onmark_footnote_render(data, name_include);
  237. data = data.replace(/^(<br>| )+/, '');
  238. data = data.replace(/(<br>| )+$/, '');
  239. data_js += '' +
  240. 'get_link_state("' + name_include + '");\n' +
  241. 'get_file_state("' + name_include + '");\n' +
  242. ''
  243. data_js = 'render_html("' + name_include + 'render_contect");\n' + data_js
  244. document.getElementById(name_id).innerHTML = data;
  245. eval(data_js);
  246. }