load_onmark_render.js 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461
  1. // Tool
  2. function do_url_change(data) {
  3. return encodeURIComponent(data);
  4. }
  5. function do_js_safe_change(data) {
  6. return data.replace(/"/g, '\\"');
  7. }
  8. function do_return_date() {
  9. var today_data = new Date();
  10. return '' +
  11. String(today_data.getFullYear()) + '-' +
  12. ((today_data.getMonth() + 1) < 10 ? '0' : '') + String(today_data.getMonth() + 1) + '-' +
  13. (today_data.getDate() < 10 ? '0' : '') + String(today_data.getDate()) + ' ' +
  14. (today_data.getHours() < 10 ? '0' : '') + String(today_data.getHours()) + ':' +
  15. (today_data.getMinutes() < 10 ? '0' : '') + String(today_data.getMinutes()) + ':' +
  16. (today_data.getSeconds() < 10 ? '0' : '') + String(today_data.getSeconds()) +
  17. '';
  18. }
  19. // Sub
  20. function do_onmark_text_render(data) {
  21. data = data.replace(/'''((?:(?!''').)+)'''/g, '<b>$1</b>');
  22. data = data.replace(/''((?:(?!'').)+)''/g, '<i>$1</i>');
  23. data = data.replace(/__((?:(?!__).)+)__/g, '<u>$1</u>');
  24. data = data.replace(/\^\^((?:(?!\^\^).)+)\^\^/g, '<sup>$1</sup>');
  25. data = data.replace(/,,((?:(?!,,).)+),,/g, '<sub>$1</sub>');
  26. data = data.replace(/--((?:(?!--).)+)--/g, '<s>$1</s>');
  27. data = data.replace(/~~((?:(?!~~).)+)~~/g, '<s>$1</s>');
  28. return data;
  29. }
  30. function do_onmark_heading_render(data) {
  31. var heading_re = /<br>(={1,6}) ?([^=]+) ?={1,6}<br>/;
  32. var heading_level_all = [0, 0, 0, 0, 0, 0];
  33. var toc_data = '<div id="toc"><div id="toc_title">TOC</div><br>';
  34. while(1) {
  35. var heading_data = data.match(heading_re);
  36. if(!heading_data) {
  37. break;
  38. }
  39. var heading_level = heading_data[1].length;
  40. heading_level_all[heading_level - 1] += 1;
  41. var i = 6;
  42. while(i > heading_level - 1) {
  43. heading_level_all[i] = 0;
  44. i -= 1;
  45. }
  46. heading_level = String(heading_level);
  47. var heading_level_string = '';
  48. i = 0;
  49. while(i < 6) {
  50. if(heading_level_all[i] !== 0) {
  51. heading_level_string += String(heading_level_all[i]) + '.';
  52. }
  53. i += 1;
  54. }
  55. var heading_level_string_no_end = heading_level_string.replace(/\.$/, '');
  56. toc_data += '' +
  57. '<span style="margin-left: ' + String((heading_level_string.match(/\./g).length - 1) * 10) + 'px;">' +
  58. '<a href="#s-' + heading_level_string_no_end + '">' +
  59. heading_level_string + ' ' +
  60. '</a>' + heading_data[2] +
  61. '</span>' +
  62. '<br>' +
  63. ''
  64. data = data.replace(heading_re,
  65. '<h' + heading_level + ' id="s-' + heading_level_string_no_end + '">' +
  66. '<a href="#toc">' + heading_level_string + '</a> ' + heading_data[2] +
  67. '</h' + heading_level + '>' +
  68. '<br>'
  69. );
  70. }
  71. data = data.replace(/\[(?:toc|목차)\]/g, toc_data + '</div>');
  72. return data;
  73. }
  74. function do_onmark_link_render(data, data_js, name_doc, name_include) {
  75. var link_num = 0;
  76. data = data.replace(/\[\[(((?!\]\]).)+)\]\]/g, function(x, x_1) {
  77. var link_split = x_1.split('|');
  78. var link_real = link_split[0];
  79. var link_out = link_split[1] ? link_split[1] : link_split[0];
  80. link_num += 1;
  81. var link_num_str = String(link_num - 1);
  82. if(link_real.match(/^http(s)?:\/\//)) {
  83. var i = 0;
  84. while(i < 2) {
  85. if(i === 0) {
  86. var var_link_type = 'href';
  87. } else {
  88. var var_link_type = 'title';
  89. }
  90. data_js += '' +
  91. 'document.getElementsByName("' + name_include + 'set_link_' + link_num_str + '")[0].' + var_link_type + ' = ' +
  92. '"' + do_js_safe_change(link_real) + '";' +
  93. '\n' +
  94. '';
  95. i += 1;
  96. }
  97. return '<a id="out_link" ' +
  98. 'name="' + name_include + 'set_link_' + link_num_str + '" ' +
  99. 'title=""' +
  100. 'href="">' + link_out + '</a>';
  101. } else {
  102. var i = 0;
  103. while(i < 2) {
  104. if(i === 0) {
  105. var var_link_type = 'href';
  106. var var_link_data = '/w/' + do_url_change(link_real);
  107. } else {
  108. var var_link_type = 'title';
  109. var var_link_data = do_js_safe_change(link_real);
  110. }
  111. data_js += '' +
  112. 'document.getElementsByName("' + name_include + 'set_link_' + link_num_str + '")[0].' + var_link_type + ' = ' +
  113. '"' + var_link_data + '";' +
  114. '\n' +
  115. '';
  116. i += 1;
  117. }
  118. return '<a class="' + name_include + 'link_finder" ' +
  119. 'name="' + name_include + 'set_link_' + link_num_str + '" ' +
  120. 'title="" ' +
  121. 'href="">' + link_out + '</a>';
  122. }
  123. });
  124. return [data, data_js];
  125. }
  126. function do_onmark_footnote_render(data, name_include) {
  127. var footnote_end_data = '';
  128. var footnote_all_data = {};
  129. var footnote_re = /(?:\[\*([^ \]]*)(?: ((?:(?!<br>|\]).)+))?\]|\[(footnote|각주)\])/;
  130. var i = 1;
  131. while(1) {
  132. var footnote_data = data.match(footnote_re);
  133. if(!footnote_data) {
  134. break;
  135. }
  136. if(!footnote_data[3]) {
  137. if(!footnote_data[2]) {
  138. var footnote_line_data = '';
  139. } else {
  140. var footnote_line_data = footnote_data[2];
  141. }
  142. if(!footnote_data[1]) {
  143. var footnote_name = String(i);
  144. } else {
  145. var footnote_name = footnote_data[1];
  146. }
  147. if(!footnote_all_data[footnote_name]) {
  148. footnote_all_data[footnote_name] = footnote_line_data;
  149. }
  150. footnote_line_data = footnote_all_data[footnote_name];
  151. footnote_end_data += '' +
  152. '<li>' +
  153. '<a href="javascript:do_open_foot(\'' + name_include + 'fn-' + String(i) + '\', 1);" ' +
  154. 'id="' + name_include + 'cfn-' + String(i) + '">' +
  155. '(' + footnote_name + ')' +
  156. '</a> <span id="' + name_include + 'fn-' + String(i) + '">' + footnote_line_data + '</span>' +
  157. '</li>' +
  158. '';
  159. data = data.replace(footnote_re, '' +
  160. '<sup>' +
  161. '<a href="javascript:do_open_foot(\'' + name_include + 'fn-' + String(i) + '\', 0);" ' +
  162. 'id="' + name_include + 'rfn-' + String(i) + '">' +
  163. '(' + footnote_name + ')' +
  164. '</a>' +
  165. '</sup><span id="' + name_include + 'dfn-' + String(i) + '"></span>' +
  166. '');
  167. i += 1;
  168. } else {
  169. if(footnote_end_data !== '') {
  170. data = data.replace(footnote_re, '<ul id="footnote_data">' + footnote_end_data + '</ul>');
  171. }
  172. footnote_end_data = '';
  173. }
  174. }
  175. if(footnote_end_data !== '') {
  176. data += '<ul id="footnote_data">' + footnote_end_data + '</ul>';
  177. }
  178. return data;
  179. }
  180. function do_onmark_macro_render(data) {
  181. data = data.replace(/\[([^[\](]+)\(((?:(?!\)\]).)+)\)\]/g, function(x, x_1, x_2) {
  182. x_1 = x_1.toLowerCase();
  183. if(x_1 === 'youtube' || x_1 === 'kakaotv' || x_1 === 'nicovideo') {
  184. var video_code = x_2.match(/^([^,]+)/);
  185. video_code = video_code ? video_code[1] : '';
  186. var video_width = x_2.match(/,(?: *)width=([0-9]+)/);
  187. video_width = video_width ? (video_width[1] + 'px') : '640px';
  188. var video_height = x_2.match(/,(?: *)height=([0-9]+)/);
  189. video_height = video_height ? (video_height[1] + 'px') : '360px';
  190. if(x_1 === 'youtube') {
  191. var video_start = x_2.match(/,(?: *)start=([0-9]+)/);
  192. video_start = video_start ? ('?' + video_start[1]) : '';
  193. video_code = video_code.replace(/^https:\/\/www\.youtube\.com\/watch\?v=/, '');
  194. video_code = video_code.replace(/^https:\/\/youtu\.be\//, '');
  195. var video_src = 'https://www.youtube.com/embed/' + video_code + video_start
  196. } else if(x_1 === 'kakaotv') {
  197. video_code = video_code.replace(/^https:\/\/tv\.kakao\.com\/channel\/9262\/cliplink\//, '');
  198. video_code = video_code.replace(/^http:\/\/tv\.kakao\.com\/v\//, '');
  199. var video_src = 'https://tv.kakao.com/embed/player/cliplink/' + video_code +'?service=kakao_tv'
  200. } else {
  201. var video_src = 'https://embed.nicovideo.jp/watch/' + video_code
  202. }
  203. return '<iframe style="width: ' + video_width + '; height: ' + video_height + ';" src="' + video_src + '" frameborder="0" allowfullscreen></iframe>';
  204. } else if(x_1 === 'anchor') {
  205. return '<span id="' + x_2 + '"></span>';
  206. } else {
  207. return '<macro_start>' + x_1 + '(' + x_2 + ')<macro_end>';
  208. }
  209. });
  210. data = data.replace(/\[([^[*()\]]+)\]/g, function(x, x_1) {
  211. x_1 = x_1.toLowerCase();
  212. if(x_1 === 'date') {
  213. return do_return_date();
  214. } else if(x_1 === 'clearfix') {
  215. return '<div style="clear:both"></div>';
  216. } else if(x_1 === 'br') {
  217. return '<br>';
  218. } else {
  219. return '<macro_start>' + x_1 + '<macro_end>';
  220. }
  221. });
  222. data = data.replace(/<macro_start>/g, '[');
  223. data = data.replace(/<macro_end>/g, ']');
  224. return data;
  225. }
  226. function do_onmark_middle_render(data, data_js, name_include) {
  227. var middle_stack = [];
  228. var middle_re = /(?:{{{([^{} ]+)|(}}}))/;
  229. var syntax_on = 0;
  230. var html_n = 0;
  231. while(1) {
  232. var middle_data = data.match(middle_re);
  233. if(!middle_data) {
  234. break;
  235. }
  236. if(middle_data[2]) {
  237. if(middle_stack.length === 0) {
  238. data = data.replace(middle_re, '<middle_end>');
  239. } else {
  240. data = data.replace(middle_re, middle_stack[middle_stack.length - 1]);
  241. middle_stack.pop();
  242. }
  243. } else {
  244. if(middle_data[1].match(/^(?:(#(?:[0-9a-f-A-F]{3}){1,2})|#([a-zA-Z]+))/)) {
  245. var color = middle_data[1].match(/^(?:(#(?:[0-9a-f-A-F]{3}){1,2})|#([a-zA-Z]+))/);
  246. color = color[1] ? color[1] : color[2];
  247. data = data.replace(middle_re, '<span style="color: ' + color + ';">');
  248. middle_stack.push('</span>');
  249. } else if(middle_data[1].match(/^(\+|-)([1-5])/)) {
  250. var font = middle_data[1].match(/^(\+|-)([1-5])/);
  251. if(font[1] === '+') {
  252. var font_size = String(100 + (20 * Number(font[2]))) + '%';
  253. } else {
  254. var font_size = String(100 - (10 * Number(font[2]))) + '%';
  255. }
  256. data = data.replace(middle_re, '<span style="font-size: ' + font_size + ';">');
  257. middle_stack.push('</span>');
  258. } else if(middle_data[1] === '#!wiki') {
  259. var wiki_re = /{{{#!wiki(?: style=["']([^"']*)["']<br>)?/;
  260. var wiki = data.match(wiki_re);
  261. var wiki_style = wiki[1] ? wiki[1] : '';
  262. data = data.replace(wiki_re, '<div_wiki_start style="' + wiki_style + '">');
  263. middle_stack.push('<div_wiki_end>');
  264. } else if(middle_data[1] === '#!html') {
  265. html_n += 1;
  266. data = data.replace(middle_re, '<span id="' + name_include + 'render_contect_' + String(html_n) + '">');
  267. middle_stack.push('</span>');
  268. } else {
  269. data = data.replace(middle_re, '<middle_start>' + middle_data[1]);
  270. }
  271. }
  272. }
  273. while(middle_stack.length !== 0) {
  274. data += middle_stack[middle_stack.length - 1];
  275. middle_stack.pop();
  276. }
  277. data = data.replace(/<br><div_wiki_end>/g, '<div_wiki_end>');
  278. data = data.replace(/<middle_start>/g, '{{{');
  279. data = data.replace(/<middle_end>/g, '}}}');
  280. return [data, data_js];
  281. }
  282. function do_onmark_last_render(data) {
  283. // middle_render 마지막 처리
  284. data = data.replace(/<div_wiki_start /g, '<div ');
  285. data = data.replace(/<div_wiki_end>/g, '</div>');
  286. // heading_render 마지막 처리
  287. data = data.replace(/(<\/h[0-9]>)<br>/g, '$1');
  288. // list_render 마지막 처리
  289. data = data.replace(/(<\/ul>)<br>/g, '$1');
  290. // br 마지막 처리
  291. data = data.replace(/^(<br>| )+/, '');
  292. data = data.replace(/(<br>| )+$/, '');
  293. return data;
  294. }
  295. function do_onmark_include_render(data, data_js, name_include) {
  296. var include_re = /\[include\(((?:(?!\)\]).)+)\)\]/;
  297. var i = 0;
  298. while(1) {
  299. i += 1;
  300. var include_data = data.match(include_re);
  301. if(!include_data) {
  302. break;
  303. }
  304. data = data.replace(include_re,
  305. '<a id="' + name_include + 'include_link" class="include_' + String(i) + '" href="/w/' + do_url_change(include_data[1]) + '">(' + include_data[1] + ')</a>' +
  306. '<div id="' + name_include + 'include_' + String(i) + '"></div>'
  307. );
  308. data_js += 'load_include("' + do_js_safe_change(include_data[1]) + '", "' + name_include + 'include_' + String(i) + '", []);\n'
  309. }
  310. return [data, data_js];
  311. }
  312. function do_onmark_nowiki_before_render(data, data_js) {
  313. return [data, data_js];
  314. }
  315. function do_onmark_table_render(data) {
  316. return data;
  317. }
  318. function do_onmark_list_render(data) {
  319. var list_re = /<br>((?:(?:(?: )+)\* (?:(?:(?!<br>).)+)<br>)+)/;
  320. var list_short_re = /((?: )+)\* ((?:(?!<br>).)+)<br>/g;
  321. while(1) {
  322. var list_data = data.match(list_re);
  323. if(!list_data) {
  324. break;
  325. }
  326. var list_end_data = '<ul>' + list_data[1].replace(list_short_re, function(x, x_1, x_2) {
  327. return '<li style="margin-left: ' + String(x_1.length * 20) + 'px;">' + x_2 + '</li>';
  328. }) + '</ul>';
  329. data = data.replace(list_re, '<br>' + list_end_data + '</br>');
  330. }
  331. return data;
  332. }
  333. // Main
  334. function do_onmark_render(test_mode = 1, name_id = '', name_include = '', name_doc = '') {
  335. if(test_mode === 0) {
  336. var data = '<br>' + document.getElementById(name_id).innerHTML.replace(/\n/g, '<br>') + '<br>';
  337. } else {
  338. var data = '<br>' + (
  339. '== namu ==\n' +
  340. 'test'
  341. ).replace(/\n/g, '<br>') + '<br>';
  342. }
  343. var data_js = '';
  344. var var_data = do_onmark_nowiki_before_render(data, data_js, name_include);
  345. data = var_data[0];
  346. data_js = var_data[1];
  347. var_data = do_onmark_include_render(data, data_js, name_include);
  348. data = var_data[0];
  349. data_js = var_data[1];
  350. var_data = do_onmark_middle_render(data, data_js, name_include);
  351. data = var_data[0];
  352. data_js = var_data[1];
  353. data = do_onmark_text_render(data);
  354. data = do_onmark_heading_render(data);
  355. data = do_onmark_table_render(data);
  356. var_data = do_onmark_link_render(data, data_js, name_doc, name_include);
  357. data = var_data[0];
  358. data_js = var_data[1];
  359. data = do_onmark_macro_render(data);
  360. data = do_onmark_list_render(data);
  361. data = do_onmark_footnote_render(data, name_include);
  362. data = do_onmark_last_render(data, name_include);
  363. data_js += '' +
  364. 'get_link_state("' + name_include + '");\n' +
  365. 'get_file_state("' + name_include + '");\n' +
  366. ''
  367. data_js = 'render_html("' + name_include + 'render_contect");\n' + data_js
  368. if(test_mode === 0) {
  369. document.getElementById(name_id).innerHTML = data;
  370. eval(data_js);
  371. } else {
  372. console.log([data, data_js]);
  373. }
  374. }
  375. do_onmark_render();