load_onmark_render.js 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486
  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. var category_data = '';
  77. var category_re = /^(분류|category):/i;
  78. var file_re = /^(파일|file):/i;
  79. data = data.replace(/\[\[(((?!\]\]).)+)\]\]/g, function(x, x_1) {
  80. var link_split = x_1.split('|');
  81. var link_real = link_split[0];
  82. var link_out = link_split[1] ? link_split[1] : link_split[0];
  83. var link_out_2 = link_split[1] ? link_split[1] : '';
  84. link_num += 1;
  85. var link_num_str = String(link_num - 1);
  86. if(link_real.match(file_re)) {
  87. var file_name = link_real.replace(file_re, '');
  88. console.log(file_name);
  89. return '';
  90. } else if(link_real.match(category_re)) {
  91. var category_link = link_real.replace(category_re, '');
  92. category_data = (category_data === '' ? '<div id="cate_all"><div id="cate">Category : ' : category_data);
  93. category_data += '' +
  94. '<a class="' + name_include + 'link_finder" ' +
  95. 'href="/w/category:' + do_url_change(category_link) + '">' +
  96. category_link +
  97. '</a> | ' +
  98. ''
  99. return '';
  100. } else if(link_real.match(/^http(s)?:\/\//)) {
  101. var i = 0;
  102. while(i < 2) {
  103. if(i === 0) {
  104. var var_link_type = 'href';
  105. } else {
  106. var var_link_type = 'title';
  107. }
  108. data_js += '' +
  109. 'document.getElementsByName("' + name_include + 'set_link_' + link_num_str + '")[0].' + var_link_type + ' = ' +
  110. '"' + do_js_safe_change(link_real) + '";' +
  111. '\n' +
  112. '';
  113. i += 1;
  114. }
  115. return '<a id="out_link" ' +
  116. 'name="' + name_include + 'set_link_' + link_num_str + '" ' +
  117. 'title=""' +
  118. 'href="">' + link_out + '</a>';
  119. } else {
  120. var i = 0;
  121. while(i < 2) {
  122. if(i === 0) {
  123. var var_link_type = 'href';
  124. var var_link_data = '/w/' + do_url_change(link_real);
  125. } else {
  126. var var_link_type = 'title';
  127. var var_link_data = do_js_safe_change(link_real);
  128. }
  129. data_js += '' +
  130. 'document.getElementsByName("' + name_include + 'set_link_' + link_num_str + '")[0].' + var_link_type + ' = ' +
  131. '"' + var_link_data + '";' +
  132. '\n' +
  133. '';
  134. i += 1;
  135. }
  136. return '<a class="' + name_include + 'link_finder" ' +
  137. 'name="' + name_include + 'set_link_' + link_num_str + '" ' +
  138. 'title="" ' +
  139. 'href="">' + link_out + '</a>';
  140. }
  141. });
  142. data += (category_data === '' ? '' : (category_data.replace(/\| $/, '') + '</div></div>'))
  143. return [data, data_js];
  144. }
  145. function do_onmark_footnote_render(data, name_include) {
  146. var footnote_end_data = '';
  147. var footnote_all_data = {};
  148. var footnote_re = /(?:\[\*([^ \]]*)(?: ((?:(?!<br>|\]).)+))?\]|\[(footnote|각주)\])/;
  149. var i = 1;
  150. while(1) {
  151. var footnote_data = data.match(footnote_re);
  152. if(!footnote_data) {
  153. break;
  154. }
  155. if(!footnote_data[3]) {
  156. if(!footnote_data[2]) {
  157. var footnote_line_data = '';
  158. } else {
  159. var footnote_line_data = footnote_data[2];
  160. }
  161. if(!footnote_data[1]) {
  162. var footnote_name = String(i);
  163. } else {
  164. var footnote_name = footnote_data[1];
  165. }
  166. if(!footnote_all_data[footnote_name]) {
  167. footnote_all_data[footnote_name] = footnote_line_data;
  168. }
  169. footnote_line_data = footnote_all_data[footnote_name];
  170. footnote_end_data += '' +
  171. '<li>' +
  172. '<a href="javascript:do_open_foot(\'' + name_include + 'fn-' + String(i) + '\', 1);" ' +
  173. 'id="' + name_include + 'cfn-' + String(i) + '">' +
  174. '(' + footnote_name + ')' +
  175. '</a> <span id="' + name_include + 'fn-' + String(i) + '">' + footnote_line_data + '</span>' +
  176. '</li>' +
  177. '';
  178. data = data.replace(footnote_re, '' +
  179. '<sup>' +
  180. '<a href="javascript:do_open_foot(\'' + name_include + 'fn-' + String(i) + '\', 0);" ' +
  181. 'id="' + name_include + 'rfn-' + String(i) + '">' +
  182. '(' + footnote_name + ')' +
  183. '</a>' +
  184. '</sup><span id="' + name_include + 'dfn-' + String(i) + '"></span>' +
  185. '');
  186. i += 1;
  187. } else {
  188. if(footnote_end_data !== '') {
  189. data = data.replace(footnote_re, '<ul id="footnote_data">' + footnote_end_data + '</ul>');
  190. }
  191. footnote_end_data = '';
  192. }
  193. }
  194. if(footnote_end_data !== '') {
  195. data += '<ul id="footnote_data">' + footnote_end_data + '</ul>';
  196. }
  197. return data;
  198. }
  199. function do_onmark_macro_render(data) {
  200. data = data.replace(/\[([^[\](]+)\(((?:(?!\)\]).)+)\)\]/g, function(x, x_1, x_2) {
  201. x_1 = x_1.toLowerCase();
  202. if(x_1 === 'youtube' || x_1 === 'kakaotv' || x_1 === 'nicovideo') {
  203. var video_code = x_2.match(/^([^,]+)/);
  204. video_code = video_code ? video_code[1] : '';
  205. var video_width = x_2.match(/,(?: *)width=([0-9]+)/);
  206. video_width = video_width ? (video_width[1] + 'px') : '640px';
  207. var video_height = x_2.match(/,(?: *)height=([0-9]+)/);
  208. video_height = video_height ? (video_height[1] + 'px') : '360px';
  209. if(x_1 === 'youtube') {
  210. var video_start = x_2.match(/,(?: *)start=([0-9]+)/);
  211. video_start = video_start ? ('?' + video_start[1]) : '';
  212. video_code = video_code.replace(/^https:\/\/www\.youtube\.com\/watch\?v=/, '');
  213. video_code = video_code.replace(/^https:\/\/youtu\.be\//, '');
  214. var video_src = 'https://www.youtube.com/embed/' + video_code + video_start
  215. } else if(x_1 === 'kakaotv') {
  216. video_code = video_code.replace(/^https:\/\/tv\.kakao\.com\/channel\/9262\/cliplink\//, '');
  217. video_code = video_code.replace(/^http:\/\/tv\.kakao\.com\/v\//, '');
  218. var video_src = 'https://tv.kakao.com/embed/player/cliplink/' + video_code +'?service=kakao_tv'
  219. } else {
  220. var video_src = 'https://embed.nicovideo.jp/watch/' + video_code
  221. }
  222. return '<iframe style="width: ' + video_width + '; height: ' + video_height + ';" src="' + video_src + '" frameborder="0" allowfullscreen></iframe>';
  223. } else if(x_1 === 'anchor') {
  224. return '<span id="' + x_2 + '"></span>';
  225. } else {
  226. return '<macro_start>' + x_1 + '(' + x_2 + ')<macro_end>';
  227. }
  228. });
  229. data = data.replace(/\[([^[*()\]]+)\]/g, function(x, x_1) {
  230. x_1 = x_1.toLowerCase();
  231. if(x_1 === 'date') {
  232. return do_return_date();
  233. } else if(x_1 === 'clearfix') {
  234. return '<div style="clear:both"></div>';
  235. } else if(x_1 === 'br') {
  236. return '<br>';
  237. } else {
  238. return '<macro_start>' + x_1 + '<macro_end>';
  239. }
  240. });
  241. data = data.replace(/<macro_start>/g, '[');
  242. data = data.replace(/<macro_end>/g, ']');
  243. return data;
  244. }
  245. function do_onmark_middle_render(data, data_js, name_include) {
  246. var middle_stack = [];
  247. var middle_re = /(?:{{{([^{} ]+)|(}}}))/;
  248. var syntax_on = 0;
  249. var html_n = 0;
  250. while(1) {
  251. var middle_data = data.match(middle_re);
  252. if(!middle_data) {
  253. break;
  254. }
  255. if(middle_data[2]) {
  256. if(middle_stack.length === 0) {
  257. data = data.replace(middle_re, '<middle_end>');
  258. } else {
  259. data = data.replace(middle_re, middle_stack[middle_stack.length - 1]);
  260. middle_stack.pop();
  261. }
  262. } else {
  263. if(middle_data[1].match(/^(?:(#(?:[0-9a-f-A-F]{3}){1,2})|#([a-zA-Z]+))/)) {
  264. var color = middle_data[1].match(/^(?:(#(?:[0-9a-f-A-F]{3}){1,2})|#([a-zA-Z]+))/);
  265. color = color[1] ? color[1] : color[2];
  266. data = data.replace(middle_re, '<span style="color: ' + color + ';">');
  267. middle_stack.push('</span>');
  268. } else if(middle_data[1].match(/^(\+|-)([1-5])/)) {
  269. var font = middle_data[1].match(/^(\+|-)([1-5])/);
  270. if(font[1] === '+') {
  271. var font_size = String(100 + (20 * Number(font[2]))) + '%';
  272. } else {
  273. var font_size = String(100 - (10 * Number(font[2]))) + '%';
  274. }
  275. data = data.replace(middle_re, '<span style="font-size: ' + font_size + ';">');
  276. middle_stack.push('</span>');
  277. } else if(middle_data[1] === '#!wiki') {
  278. var wiki_re = /{{{#!wiki(?: style=["']([^"']*)["']<br>)?/;
  279. var wiki = data.match(wiki_re);
  280. var wiki_style = wiki[1] ? wiki[1] : '';
  281. data = data.replace(wiki_re, '<div_wiki_start style="' + wiki_style + '">');
  282. middle_stack.push('<div_wiki_end>');
  283. } else if(middle_data[1] === '#!html') {
  284. html_n += 1;
  285. data = data.replace(middle_re, '<span id="' + name_include + 'render_contect_' + String(html_n) + '">');
  286. middle_stack.push('</span>');
  287. } else if(middle_data[1] === '#!folding') {
  288. } else {
  289. data = data.replace(middle_re, '<middle_start>' + middle_data[1]);
  290. }
  291. }
  292. }
  293. while(middle_stack.length !== 0) {
  294. data += middle_stack[middle_stack.length - 1];
  295. middle_stack.pop();
  296. }
  297. data = data.replace(/<br><div_wiki_end>/g, '<div_wiki_end>');
  298. data = data.replace(/<middle_start>/g, '{{{');
  299. data = data.replace(/<middle_end>/g, '}}}');
  300. return [data, data_js];
  301. }
  302. function do_onmark_last_render(data) {
  303. // middle_render 마지막 처리
  304. data = data.replace(/<div_wiki_start /g, '<div ');
  305. data = data.replace(/<div_wiki_end>/g, '</div>');
  306. // heading_render 마지막 처리
  307. data = data.replace(/(<\/h[0-9]>)<br>/g, '$1');
  308. // list_render 마지막 처리
  309. data = data.replace(/(<\/ul>)<br>/g, '$1');
  310. // br 마지막 처리
  311. data = data.replace(/^(<br>| )+/, '');
  312. data = data.replace(/(<br>| )+$/, '');
  313. return data;
  314. }
  315. function do_onmark_include_render(data, data_js, name_include) {
  316. var include_re = /\[include\(((?:(?!\)\]).)+)\)\]/;
  317. var i = 0;
  318. while(1) {
  319. i += 1;
  320. var include_data = data.match(include_re);
  321. if(!include_data) {
  322. break;
  323. }
  324. data = data.replace(include_re,
  325. '<a id="' + name_include + 'include_link" class="include_' + String(i) + '" href="/w/' + do_url_change(include_data[1]) + '">(' + include_data[1] + ')</a>' +
  326. '<div id="' + name_include + 'include_' + String(i) + '"></div>'
  327. );
  328. data_js += 'load_include("' + do_js_safe_change(include_data[1]) + '", "' + name_include + 'include_' + String(i) + '", []);\n'
  329. }
  330. return [data, data_js];
  331. }
  332. function do_onmark_nowiki_before_render(data, data_js) {
  333. return [data, data_js];
  334. }
  335. function do_onmark_table_render(data) {
  336. return data;
  337. }
  338. function do_onmark_list_render(data) {
  339. var list_re = /<br>((?:(?:(?: )+)\* (?:(?:(?!<br>).)+)<br>)+)/;
  340. var list_short_re = /((?: )+)\* ((?:(?!<br>).)+)<br>/g;
  341. while(1) {
  342. var list_data = data.match(list_re);
  343. if(!list_data) {
  344. break;
  345. }
  346. var list_end_data = '<ul>' + list_data[1].replace(list_short_re, function(x, x_1, x_2) {
  347. return '<li style="margin-left: ' + String(x_1.length * 20) + 'px;">' + x_2 + '</li>';
  348. }) + '</ul>';
  349. data = data.replace(list_re, '<br>' + list_end_data + '</br>');
  350. }
  351. return data;
  352. }
  353. // Main
  354. function do_onmark_render(test_mode = 1, name_id = '', name_include = '', name_doc = '') {
  355. if(test_mode === 0) {
  356. var data = '<br>' + document.getElementById(name_id).innerHTML.replace(/\n/g, '<br>') + '<br>';
  357. } else {
  358. var data = '<br>' + (
  359. '== namu ==\n' +
  360. 'test'
  361. ).replace(/\n/g, '<br>') + '<br>';
  362. }
  363. var data_js = '';
  364. var data_backlink = [];
  365. var var_data = do_onmark_nowiki_before_render(data, data_js, name_include);
  366. data = var_data[0];
  367. data_js = var_data[1];
  368. var_data = do_onmark_include_render(data, data_js, name_include);
  369. data = var_data[0];
  370. data_js = var_data[1];
  371. var_data = do_onmark_middle_render(data, data_js, name_include);
  372. data = var_data[0];
  373. data_js = var_data[1];
  374. data = do_onmark_text_render(data);
  375. data = do_onmark_heading_render(data);
  376. data = do_onmark_table_render(data);
  377. var_data = do_onmark_link_render(data, data_js, name_doc, name_include);
  378. data = var_data[0];
  379. data_js = var_data[1];
  380. data = do_onmark_macro_render(data);
  381. data = do_onmark_list_render(data);
  382. data = do_onmark_footnote_render(data, name_include);
  383. data = do_onmark_last_render(data, name_include);
  384. data_js += '' +
  385. 'get_link_state("' + name_include + '");\n' +
  386. 'get_file_state("' + name_include + '");\n' +
  387. ''
  388. data_js = 'render_html("' + name_include + 'render_contect");\n' + data_js
  389. if(test_mode === 0) {
  390. document.getElementById(name_id).innerHTML = data;
  391. eval(data_js);
  392. } else {
  393. console.log([data, data_js]);
  394. }
  395. }
  396. do_onmark_render();