render_onmark.js 39 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036
  1. // 인터위키
  2. // Tool
  3. function do_url_change(data) {
  4. return encodeURIComponent(data);
  5. }
  6. function do_nowiki_change(data, data_nowiki) {
  7. return data.replace(/<span id="((?:.*)(?:nowiki_(?:[^"]+)))"><\/span>/, function(x, x_1) {
  8. return data_nowiki[x_1];
  9. });
  10. }
  11. function do_link_change(data, data_nowiki, no_change, data_nowiki) {
  12. data = data.replace(/^:/, '');
  13. if(no_change === 0) {
  14. data = data.replace(/^사용자:/, 'user:');
  15. data = data.replace(/^분류:/, 'category:');
  16. data = data.replace(/^파일:/, 'file:');
  17. }
  18. var data_var = data.split('#');
  19. var link_main = data.replace(/#(.*)$/, '');
  20. var link_sub = data_var.length !== 1 ? ('#' + data_var[data_var.length - 1]) : '';
  21. link_main = do_nowiki_change(link_main, data_nowiki);
  22. link_main = do_xss_change(link_main);
  23. return [link_main, link_sub];
  24. }
  25. function do_darkmode_split(data) {
  26. return data.split(',')[0];
  27. }
  28. function do_js_safe_change(data) {
  29. data = data.replace(/\\/g, '\\\\');
  30. data = data.replace(/"/g, '\\"');
  31. data = data.replace(/\n/g, '<br>');
  32. return data;
  33. }
  34. function do_math_try_insert(name_ob, data) {
  35. return '' +
  36. 'try {\n' +
  37. 'katex.render("' + data + '", document.getElementById(\"' + name_ob + '\"));\n' +
  38. '} catch {\n' +
  39. 'document.getElementById(\"' + name_ob + '\").innerHTML = "<span style=\'color: red;\'>' + data + '</span>";\n' +
  40. '}\n' +
  41. ''
  42. }
  43. function do_data_try_insert(name_ob, data) {
  44. return '' +
  45. 'if(document.getElementById("' + name_ob + '")) {\n' +
  46. 'document.getElementById("' + name_ob + '").innerHTML = "' + data + '";\n' +
  47. '}\n' +
  48. ''
  49. }
  50. function do_px_add(data) {
  51. return data.match(/^[0-9]+$/) ? (data + 'px') : data;
  52. }
  53. function do_return_date() {
  54. var today_data = new Date();
  55. return '' +
  56. String(today_data.getFullYear()) + '-' +
  57. ((today_data.getMonth() + 1) < 10 ? '0' : '') + String(today_data.getMonth() + 1) + '-' +
  58. (today_data.getDate() < 10 ? '0' : '') + String(today_data.getDate()) + ' ' +
  59. (today_data.getHours() < 10 ? '0' : '') + String(today_data.getHours()) + ':' +
  60. (today_data.getMinutes() < 10 ? '0' : '') + String(today_data.getMinutes()) + ':' +
  61. (today_data.getSeconds() < 10 ? '0' : '') + String(today_data.getSeconds()) +
  62. '';
  63. }
  64. function do_xss_change(data) {
  65. data = data.replace(/&lt;/g, '<');
  66. data = data.replace(/&gt;/g, '>');
  67. data = data.replace(/&amp;/g, '&');
  68. return data;
  69. }
  70. // Sub
  71. function do_onmark_text_render(data) {
  72. data = data.replace(/'''((?:(?!''').)+)'''/g, '<b>$1</b>');
  73. data = data.replace(/''((?:(?!'').)+)''/g, '<i>$1</i>');
  74. data = data.replace(/__((?:(?!__).)+)__/g, '<u>$1</u>');
  75. data = data.replace(/\^\^((?:(?!\^\^).)+)\^\^/g, '<sup>$1</sup>');
  76. data = data.replace(/,,((?:(?!,,).)+),,/g, '<sub>$1</sub>');
  77. data = data.replace(/--((?:(?!--).)+)--/g, '<s>$1</s>');
  78. data = data.replace(/~~((?:(?!~~).)+)~~/g, '<s>$1</s>');
  79. return data;
  80. }
  81. function do_onmark_heading_render(data, name_doc, name_include) {
  82. var heading_re = /\n(={1,6})(#)? ?([^=#]+) ?#?={1,6}\n/;
  83. var heading_level_all = [0, 0, 0, 0, 0, 0];
  84. var toc_data = '';
  85. var toc_n = 0;
  86. while(1) {
  87. toc_n += 1;
  88. var heading_data = data.match(heading_re);
  89. if(!heading_data) {
  90. break;
  91. }
  92. if(toc_data === '') {
  93. toc_data += '<div id="toc"><div id="toc_title">TOC</div>\n';
  94. }
  95. var heading_level = heading_data[1].length;
  96. heading_level_all[heading_level - 1] += 1;
  97. var i = 6;
  98. while(i > heading_level - 1) {
  99. heading_level_all[i] = 0;
  100. i -= 1;
  101. }
  102. heading_level = String(heading_level);
  103. var heading_level_string = '';
  104. i = 0;
  105. while(i < 6) {
  106. if(heading_level_all[i] !== 0) {
  107. heading_level_string += String(heading_level_all[i]) + '.';
  108. }
  109. i += 1;
  110. }
  111. var heading_level_string_no_end = heading_level_string.replace(/\.$/, '');
  112. toc_data += '' +
  113. '<span style="margin-left: ' + String((heading_level_string.match(/\./g).length - 1) * 10) + 'px;">' +
  114. '<a href="#s-' + heading_level_string_no_end + '">' +
  115. heading_level_string + ' ' +
  116. '</a>' + heading_data[3] +
  117. '</span>' +
  118. '\n' +
  119. ''
  120. data = data.replace(heading_re,
  121. '\n<start_point>' +
  122. (toc_n === 1 ? '' : '</div>') +
  123. '<h' + heading_level + ' id="s-' + heading_level_string_no_end + '">' +
  124. '<a href="#toc">' + heading_level_string + '</a> ' +
  125. heading_data[3] +
  126. '<a id="edit_load_' + String(toc_n) + '" ' +
  127. 'style="font-size: 70%;"' +
  128. 'href="/edit/' + do_url_change(name_doc) + '?section=' + String(toc_n) + '">✎</a> ' +
  129. '<a href="javascript:void(0);" ' +
  130. 'onclick="javascript:do_open_folding(\'' + name_include + 'in_data_' + String(toc_n) + '\', this);"' +
  131. 'style="font-size: 70%;">' + (heading_data[2] ? '⊕' : '⊖') + '</a>' +
  132. '</h' + heading_level + '>' +
  133. '<div id="' + name_include + 'in_data_' + String(toc_n) + '" ' +
  134. 'style="display: ' + (heading_data[2] ? 'none' : 'block') + ';">' +
  135. '<end_point>\n'
  136. );
  137. }
  138. if(toc_data !== '') {
  139. toc_data += '</div>';
  140. data += '</div>';
  141. }
  142. var toc_auto_add = data.match(/\[(?:목차|toc)\(no\)\]/);
  143. var toc_re = /\[(?:toc|목차)\]/g;
  144. if(toc_auto_add) {
  145. data = data.replace(/\[(?:목차|toc)\(no\)\]/g, '');
  146. } else {
  147. if(!data.match(toc_re)) {
  148. data = data.replace(/(<h[1-6] (?:[^>]+)>)/, toc_data + '$1');
  149. }
  150. }
  151. data = data.replace(toc_re, toc_data);
  152. return data;
  153. }
  154. function do_onmark_link_render(data, data_js, name_doc, name_include, data_nowiki) {
  155. var num_link = 0;
  156. var category_data = '';
  157. var category_re = /^(분류|category):/i;
  158. var file_re = /^(파일|file|외부|out):/i;
  159. data = data.replace(/\[\[(((?!\]\]).)+)\]\]/g, function(x, x_1) {
  160. var link_split = x_1.split('|');
  161. var link_real = link_split[0];
  162. var link_out = link_split[1] ? link_split[1] : link_split[0];
  163. var link_out_2 = link_split[1] ? link_split[1] : '';
  164. num_link += 1;
  165. var num_link_str = String(num_link - 1);
  166. if(link_real.match(file_re)) {
  167. var file_load_type = link_real.match(file_re)[1];
  168. var file_name = link_real.replace(file_re, '');
  169. if(file_load_type === '파일' || file_load_type === 'file') {
  170. var file_type = file_name.split('.');
  171. file_name = file_type.slice(0, file_type.length - 1).join('.');
  172. file_type = file_type[file_type.length - 1];
  173. var file_src = do_url_change(file_name) + '.' + file_type;
  174. var file_alt = file_name + '.' + file_type;
  175. var file_exist = 1;
  176. } else {
  177. var file_src = file_name;
  178. var file_alt = file_name;
  179. var file_exist = 0;
  180. }
  181. var file_style = '';
  182. var file_bgcolor = '';
  183. var file_align = '';
  184. var file_set = link_out_2.split('&amp;');
  185. var i = 0;
  186. while(file_set[i]) {
  187. var file_set_name = file_set[i].split('=');
  188. var file_set_data = file_set_name[1];
  189. file_set_name = file_set_name[0];
  190. if(file_set_name === 'width') {
  191. file_style += 'width:' + file_set_data + ';';
  192. } else if(file_set_name === 'height') {
  193. file_style += 'height:' + file_set_data + ';';
  194. } else if(file_set_name === 'bgcolor') {
  195. file_bgcolor += 'background:' + file_set_data + ';';
  196. } else if(file_set_name === 'alt') {
  197. file_alt += file_set_data;
  198. } else if(file_set_name === 'align') {
  199. if(file_set_data === 'center') {
  200. file_align = 'display: block; text-align: center;';
  201. } else {
  202. file_align = 'float: ' + file_set_data + ';';
  203. }
  204. }
  205. i += 1;
  206. }
  207. return '' +
  208. '<span style="' + file_align + '">' +
  209. '<span style="' + file_bgcolor + '" ' +
  210. 'class="' + name_include + 'file_finder" ' +
  211. 'under_style="' + file_style + '" ' +
  212. 'under_alt="' + file_alt + '" ' +
  213. 'under_src="' + file_src + '" ' +
  214. 'under_href="' + (file_exist === 0 ? "out_link" : '/upload?name=' + do_url_change(file_name)) + '">' +
  215. '</span>' +
  216. '</span>' +
  217. ''
  218. } else if(link_real.match(category_re)) {
  219. var category_link = link_real.replace(category_re, '');
  220. category_data = (category_data === '' ? '<div id="cate_all"><div id="cate">Category : ' : category_data);
  221. category_data += '' +
  222. '<a class="' + name_include + 'link_finder" ' +
  223. 'href="/w/category:' + do_url_change(category_link) + '">' +
  224. category_link +
  225. '</a> | ' +
  226. ''
  227. return '';
  228. } else if(link_real.match(/^http(s)?:\/\//)) {
  229. var i = 0;
  230. while(i < 2) {
  231. if(i === 0) {
  232. var var_link_type = 'href';
  233. } else {
  234. var var_link_type = 'title';
  235. }
  236. data_js += '' +
  237. 'document.getElementsByName("' + name_include + 'set_link_' + num_link_str + '")[0].' + var_link_type + ' = ' +
  238. '"' + do_js_safe_change(link_real) + '";' +
  239. '\n' +
  240. '';
  241. i += 1;
  242. }
  243. return '<a id="out_link" ' +
  244. 'name="' + name_include + 'set_link_' + num_link_str + '" ' +
  245. 'title=""' +
  246. 'href="">' + link_out + '</a>';
  247. } else {
  248. if(link_real.match(/^\//)) {
  249. link_real = name_doc + link_real;
  250. } else if(link_real === '../') {
  251. link_real = name_doc.split('/');
  252. if(link_real.length > 1) {
  253. link_real = link_real.slice(0, link_real.length - 1).join('/');
  254. } else {
  255. link_real = name_doc;
  256. }
  257. }
  258. var i = 0;
  259. while(i < 2) {
  260. if(i === 0) {
  261. var link_data_var = do_link_change(link_real, data_nowiki, 0, data_nowiki);
  262. var link_main = link_data_var[0];
  263. var link_sub = link_data_var[1];
  264. var var_link_type = 'href';
  265. if(link_main === '') {
  266. var var_link_data = link_sub;
  267. } else {
  268. var var_link_data = '/w/' + do_url_change(link_main) + link_sub;
  269. }
  270. } else {
  271. var var_link_type = 'title';
  272. var var_link_data = do_js_safe_change(link_main) + link_sub;
  273. }
  274. data_js += '' +
  275. 'document.getElementsByName("' + name_include + 'set_link_' + num_link_str + '")[0].' + var_link_type + ' = ' +
  276. '"' + var_link_data + '";' +
  277. '\n' +
  278. '';
  279. i += 1;
  280. }
  281. return '<a class="' + name_include + 'link_finder" ' +
  282. 'name="' + name_include + 'set_link_' + num_link_str + '" ' +
  283. 'title="" ' +
  284. 'href="">' + link_out + '</a>';
  285. }
  286. });
  287. data += (category_data === '' ? '' : (category_data.replace(/\| $/, '') + '</div></div>'));
  288. return [data, data_js];
  289. }
  290. function do_onmark_footnote_render(data, name_include) {
  291. var footnote_end_data = '';
  292. var footnote_all_data = {};
  293. var footnote_re = /(?:\[\*([^ \]]*)(?: ((?:(?!\]).)+))?\]|\[(footnote|각주)\])/;
  294. var i = 1;
  295. while(1) {
  296. var footnote_data = data.match(footnote_re);
  297. if(!footnote_data) {
  298. break;
  299. }
  300. if(!footnote_data[3]) {
  301. if(!footnote_data[2]) {
  302. var footnote_line_data = '';
  303. } else {
  304. var footnote_line_data = footnote_data[2];
  305. }
  306. if(!footnote_data[1]) {
  307. var footnote_name = String(i);
  308. } else {
  309. var footnote_name = footnote_data[1];
  310. }
  311. if(!footnote_all_data[footnote_name]) {
  312. footnote_all_data[footnote_name] = footnote_line_data;
  313. }
  314. footnote_line_data = footnote_all_data[footnote_name];
  315. footnote_end_data += '' +
  316. '<li>' +
  317. '<a href="javascript:do_open_foot(\'' + name_include + 'fn-' + String(i) + '\', 1);" ' +
  318. 'id="' + name_include + 'cfn-' + String(i) + '">' +
  319. '(' + footnote_name + ')' +
  320. '</a> <span id="' + name_include + 'fn-' + String(i) + '">' + footnote_line_data + '</span>' +
  321. '</li>' +
  322. '';
  323. data = data.replace(footnote_re, '' +
  324. '<sup>' +
  325. '<a href="javascript:do_open_foot(\'' + name_include + 'fn-' + String(i) + '\', 0);" ' +
  326. 'id="' + name_include + 'rfn-' + String(i) + '">' +
  327. '(' + footnote_name + ')' +
  328. '</a>' +
  329. '</sup><span id="' + name_include + 'dfn-' + String(i) + '"></span>' +
  330. '');
  331. i += 1;
  332. } else {
  333. if(footnote_end_data !== '') {
  334. data = data.replace(footnote_re, '<ul id="footnote_data">' + footnote_end_data + '</ul>');
  335. }
  336. footnote_end_data = '';
  337. }
  338. }
  339. if(footnote_end_data !== '') {
  340. data += '<ul id="footnote_data">' + footnote_end_data + '</ul>';
  341. }
  342. return data;
  343. }
  344. function do_onmark_macro_render(data) {
  345. data = data.replace(/\[([^[\](]+)\(((?:(?!\)\]).)+)\)\]/g, function(x, x_1, x_2) {
  346. x_1 = x_1.toLowerCase();
  347. if(x_1 === 'youtube' || x_1 === 'kakaotv' || x_1 === 'nicovideo') {
  348. var video_code = x_2.match(/^([^,]+)/);
  349. video_code = video_code ? video_code[1] : '';
  350. var video_width = x_2.match(/,(?: *)width=([0-9]+)/);
  351. video_width = video_width ? (video_width[1] + 'px') : '640px';
  352. var video_height = x_2.match(/,(?: *)height=([0-9]+)/);
  353. video_height = video_height ? (video_height[1] + 'px') : '360px';
  354. if(x_1 === 'youtube') {
  355. var video_start = x_2.match(/,(?: *)start=([0-9]+)/);
  356. video_start = video_start ? ('?' + video_start[1]) : '';
  357. video_code = video_code.replace(/^https:\/\/www\.youtube\.com\/watch\?v=/, '');
  358. video_code = video_code.replace(/^https:\/\/youtu\.be\//, '');
  359. var video_src = 'https://www.youtube.com/embed/' + video_code + video_start
  360. } else if(x_1 === 'kakaotv') {
  361. video_code = video_code.replace(/^https:\/\/tv\.kakao\.com\/channel\/9262\/cliplink\//, '');
  362. video_code = video_code.replace(/^http:\/\/tv\.kakao\.com\/v\//, '');
  363. var video_src = 'https://tv.kakao.com/embed/player/cliplink/' + video_code +'?service=kakao_tv'
  364. } else {
  365. var video_src = 'https://embed.nicovideo.jp/watch/' + video_code
  366. }
  367. return '<iframe style="width: ' + video_width + '; height: ' + video_height + ';" src="' + video_src + '" frameborder="0" allowfullscreen></iframe>';
  368. } else if(x_1 === 'anchor') {
  369. return '<span id="' + x_2 + '"></span>';
  370. } else if(x_1 === 'dday') {
  371. var date_old = new Date(x_2);
  372. var date_now = new Date(do_return_date());
  373. var date_end = Math.floor((date_now - date_old) / (24 * 60 * 60 * 1000));
  374. return date_end > 0 ? '+' + date_end : '-' + date_end;
  375. } else if(x_1 === 'age') {
  376. var date_old = new Date(x_2);
  377. var date_now = new Date(do_return_date());
  378. var date_end = Math.floor((date_now - date_old) / (365 * 24 * 60 * 60 * 1000));
  379. return date_end > 0 ? date_end : '';
  380. } else if(x_1 === 'pagecount') {
  381. return '0';
  382. } else {
  383. return '<macro_start>' + x_1 + '(' + x_2 + ')<macro_end>';
  384. }
  385. });
  386. data = data.replace(/\[([^[*()\]]+)\]/g, function(x, x_1) {
  387. x_1 = x_1.toLowerCase();
  388. if(x_1 === 'date') {
  389. return do_return_date();
  390. } else if(x_1 === 'clearfix') {
  391. return '<div style="clear:both"></div>';
  392. } else if(x_1 === 'br') {
  393. return '<br>';
  394. } else if(x_1 === 'pagecount') {
  395. return '0';
  396. } else {
  397. return '<macro_start>' + x_1 + '<macro_end>';
  398. }
  399. });
  400. data = data.replace(/<macro_start>/g, '[');
  401. data = data.replace(/<macro_end>/g, ']');
  402. return data;
  403. }
  404. function do_onmark_middle_render(data, data_js, name_include, data_nowiki, name_doc) {
  405. var middle_stack = [];
  406. var middle_re = /(?:{{{([^{} ]*)|(}}}))/;
  407. var syntax_on = 0;
  408. var html_n = 0;
  409. var folding_n = 0;
  410. while(1) {
  411. var middle_data = data.match(middle_re);
  412. if(!middle_data) {
  413. break;
  414. }
  415. if(middle_data[2]) {
  416. if(middle_stack.length === 0) {
  417. data = data.replace(middle_re, '<middle_end>');
  418. } else {
  419. data = data.replace(middle_re, middle_stack[middle_stack.length - 1]);
  420. middle_stack.pop();
  421. }
  422. } else {
  423. if(middle_stack.includes('</code>')) {
  424. data = data.replace(middle_re, '<middle_start>' + middle_data[1]);
  425. middle_stack.push('<middle_end>');
  426. } else {
  427. if(middle_data[1].match(/^(?:(#(?:[0-9a-f-A-F]{3}){1,2})|#([a-zA-Z]+))/)) {
  428. var color = middle_data[1].match(/^(?:(#(?:[0-9a-f-A-F]{3}){1,2})|#([a-zA-Z]+))/);
  429. color = color[1] ? color[1] : color[2];
  430. data = data.replace(middle_re, '<span style="color: ' + color + ';">');
  431. middle_stack.push('</span>');
  432. } else if(middle_data[1].match(/^(\+|-)([1-5])/)) {
  433. var font = middle_data[1].match(/^(\+|-)([1-5])/);
  434. if(font[1] === '+') {
  435. var font_size = String(100 + (20 * Number(font[2]))) + '%';
  436. } else {
  437. var font_size = String(100 - (10 * Number(font[2]))) + '%';
  438. }
  439. data = data.replace(middle_re, '<span style="font-size: ' + font_size + ';">');
  440. middle_stack.push('</span>');
  441. } else if(middle_data[1] === '#!wiki') {
  442. var wiki_re = /{{{#!wiki(?: style=["']([^"']*)["']\n)?/;
  443. var wiki = data.match(wiki_re);
  444. var wiki_style = wiki[1] ? wiki[1] : '';
  445. data = data.replace(wiki_re, '<wiki_start style="' + wiki_style + '">');
  446. middle_stack.push('<wiki_end>');
  447. } else if(middle_data[1] === '#!html') {
  448. html_n += 1;
  449. data = data.replace(middle_re, '<span id="' + name_include + 'render_contect_' + String(html_n) + '">');
  450. middle_stack.push('</span>');
  451. } else if(middle_data[1] === '#!folding') {
  452. folding_n += 1;
  453. var folding_re = /{{{#!folding(?: ([^\n]+)\n)?/;
  454. var folding = data.match(folding_re);
  455. var folding_name = folding[1] ? folding[1] : 'open';
  456. if(folding_n > 100) {
  457. break;
  458. }
  459. data_js += '' +
  460. 'if(document.getElementById("get_' + name_include + 'folding_' + String(folding_n) + '")) { ' +
  461. 'document.getElementById("get_' + name_include + 'folding_' + String(folding_n) + '").innerHTML = ' +
  462. '"' + do_js_safe_change(folding_name) + '"; ' +
  463. '' +
  464. '}' +
  465. '\n' +
  466. ''
  467. data = data.replace(folding_re, '' +
  468. '<div style="display: inline-block;">' +
  469. '<b>' +
  470. '<a href="javascript:do_open_folding(\'' + name_include + 'folding_' + String(folding_n) + '\');" ' +
  471. 'id="get_' + name_include + 'folding_' + String(folding_n) + '">' +
  472. '</a>' +
  473. '</b>' +
  474. '</div>' +
  475. '<div id="' + name_include + 'folding_' + String(folding_n) + '" style="display: none;">' +
  476. '\n' +
  477. '<wiki_start style="">' +
  478. '');
  479. middle_stack.push('<folding_end>');
  480. } else {
  481. data = data.replace(middle_re, '<nowiki_start>' + middle_data[1]);
  482. middle_stack.push('<nowiki_end>');
  483. }
  484. }
  485. }
  486. }
  487. while(middle_stack.length !== 0) {
  488. data += middle_stack[middle_stack.length - 1];
  489. middle_stack.pop();
  490. }
  491. data = data.replace(/<folding_end>/g, '<wiki_end></div>');
  492. data = data.replace(/\n<wiki_end>/g, '<wiki_end>');
  493. data = data.replace(/<middle_start>/g, '{{{');
  494. data = data.replace(/<middle_end>/g, '}}}');
  495. var code_re = /<nowiki_start>((?:(?!<nowiki_start>|<nowiki_end>).)+)<nowiki_end>/s;
  496. var code_n = 0;
  497. while(1) {
  498. code_n += 1;
  499. var code_data = data.match(code_re);
  500. if(!code_data) {
  501. break;
  502. }
  503. data_nowiki[name_include + 'nowiki_mid_' + String(code_n)] = code_data[1];
  504. data_js += do_data_try_insert(name_include + 'nowiki_mid_' + String(code_n), do_js_safe_change(code_data[1]));
  505. data = data.replace(code_re, '<span id="' + name_include + 'nowiki_mid_' + String(code_n) + '"></span>');
  506. }
  507. var wiki_re = /<wiki_start ([^>]+)>((?:(?!<wiki_start (?:[^>]+)>|<wiki_end>).)+)<wiki_end>/s;
  508. var wiki_n = 0;
  509. while(1) {
  510. wiki_n += 1;
  511. var wiki_data = data.match(wiki_re);
  512. if(!wiki_data) {
  513. break;
  514. }
  515. var wiki_data_style = wiki_data[1];
  516. wiki_data = do_nowiki_change(wiki_data[2]);
  517. wiki_data = do_onmark_render('manual', '', name_include + 'wiki_' + String(wiki_n) + '_', name_doc, wiki_data);
  518. data_js += wiki_data[1];
  519. data = data.replace(wiki_re, '<div ' + wiki_data_style + '>' + wiki_data[0] + '</div>');
  520. }
  521. return [data, data_js, data_nowiki];
  522. }
  523. function do_onmark_last_render(data) {
  524. // middle_render 마지막 처리
  525. data = data.replace(/<wiki_start /g, '<div ');
  526. data = data.replace(/<wiki_end>/g, '</div>');
  527. // heading_render 마지막 처리
  528. data = data.replace(/\n?<start_point>/g, '');
  529. data = data.replace(/<end_point>\n?/g, '');
  530. // list_render 마지막 처리
  531. data = data.replace(/(<\/ul>)\n/g, '$1');
  532. // br 마지막 처리
  533. data = data.replace(/^(\n| )+/, '');
  534. data = data.replace(/(\n| )+$/, '');
  535. data = data.replace(/\n/g, '<br>');
  536. return data;
  537. }
  538. function do_onmark_include_render(data, data_js, name_include, data_nowiki) {
  539. var include_re = /\[include\(((?:(?!\)\]).)+)\)\]/;
  540. var i = 0;
  541. while(1) {
  542. i += 1;
  543. var include_data = data.match(include_re);
  544. if(!include_data) {
  545. break;
  546. }
  547. var include_name = do_nowiki_change(
  548. include_data[1].match(/^([^,]+)/)[1],
  549. data_nowiki
  550. );
  551. var include_add_re = /, *([^=]+)=((?:(?:(?!\)]|,).)+)+)/;
  552. var include_add_data = []
  553. var include_data = include_data[1];
  554. while(1) {
  555. var include_add = include_data.match(include_add_re);
  556. if(!include_add) {
  557. break;
  558. }
  559. include_add_data.push([
  560. include_add[1],
  561. do_nowiki_change(include_add[2], data_nowiki)
  562. ]);
  563. include_data = include_data.replace(include_add_re, '');
  564. }
  565. data = data.replace(include_re,
  566. '<a id="' + name_include + 'include_link" class="include_' + String(i) + '" href="">(' + include_name + ')</a>' +
  567. '<div id="' + name_include + 'include_' + String(i) + '"></div>'
  568. );
  569. data_js += 'load_include("' + do_js_safe_change(include_name) + '", "' + name_include + 'include_' + String(i) + '", ' + JSON.stringify(include_add_data) + ');\n'
  570. }
  571. return [data, data_js];
  572. }
  573. function do_onmark_nowiki_before_render(data, data_js, name_include, data_nowiki) {
  574. var num_nowiki = 0;
  575. data = data.replace(/\\(.)/g, function(x, x_1) {
  576. num_nowiki += 1;
  577. data_nowiki[name_include + 'nowiki_one_' + String(num_nowiki)] = x_1;
  578. data_js += do_data_try_insert(name_include + 'nowiki_one_' + String(num_nowiki), do_js_safe_change(x_1));
  579. return '<span id="' + name_include + 'nowiki_one_' + String(num_nowiki) + '"></span>';
  580. });
  581. return [data, data_js, data_nowiki, num_nowiki];
  582. }
  583. function do_onmark_table_render_sub(data, data_col) {
  584. var data_option_all = {
  585. "div" : "",
  586. "table" : "",
  587. "tr" : "",
  588. "td" : "",
  589. "col" : data_col,
  590. "colspan" : "",
  591. "rowspan" : "",
  592. "data" : ""
  593. };
  594. var table_option_re = /&lt;((?:(?!&lt;|&gt;).)+)&gt;/;
  595. while(1) {
  596. var no_option = '';
  597. var align_auto = 1;
  598. var data_option = data.match(table_option_re);
  599. if(!data_option) {
  600. break;
  601. }
  602. data_option = data_option[1];
  603. var data_option_var = data_option.split('=');
  604. if(data_option_var.length === 2) {
  605. var table_option_name = data_option_var[0].replace(/ /g, '');
  606. var table_option_data = data_option_var[1].replace(/"/g, '');
  607. if(table_option_name === 'tablebgcolor') {
  608. // table
  609. data_option_all['table'] += 'background:' + do_darkmode_split(table_option_data) + ';';
  610. } else if(table_option_name === 'tablewidth') {
  611. data_option_all['table'] += 'width:' + do_px_add(table_option_data) + ';';
  612. } else if(table_option_name === 'tableheight') {
  613. data_option_all['table'] += 'height:' + do_px_add(table_option_data) + ';';
  614. } else if(table_option_name === 'tablealign') {
  615. if(table_option_data === 'right') {
  616. data_option_all['div'] += 'float:right;';
  617. } else if(table_option_data === 'center') {
  618. data_option_all['div'] += 'margin:auto;';
  619. data_option_all['table'] += 'margin:auto;';
  620. }
  621. } else if(table_option_name === 'tabletextalign') {
  622. data_option_all['table'] += 'text-align:' + table_option_data + ';';
  623. } else if(table_option_name === 'tablecolor') {
  624. data_option_all['table'] += 'color:' + do_darkmode_split(table_option_data) + ';';
  625. } else if(table_option_name === 'tablebordercolor') {
  626. data_option_all['table'] += 'border:2px solid ' + do_darkmode_split(table_option_data) + ';';
  627. } else if(table_option_name === 'rowbgcolor') {
  628. // tr
  629. data_option_all['tr'] += 'background:' + do_darkmode_split(table_option_data) + ';';
  630. } else if(table_option_name === 'rowtextalign') {
  631. data_option_all['tr'] += 'text-align:' + table_option_data + ';';
  632. } else if(table_option_name === 'rowcolor') {
  633. data_option_all['tr'] += 'color:' + do_darkmode_split(table_option_data) + ';';
  634. } else if(table_option_name === 'colcolor') {
  635. // col
  636. data_option_all['col'] += 'color:' + do_darkmode_split(table_option_data) + ';';
  637. } else if(table_option_name === 'colbgcolor') {
  638. data_option_all['col'] += 'background:' + do_darkmode_split(table_option_data) + ';';
  639. } else if(table_option_name === 'bgcolor') {
  640. // td
  641. data_option_all['td'] += 'background:' + do_darkmode_split(table_option_data) + ';';
  642. } else if(table_option_name === 'color') {
  643. data_option_all['td'] += 'color:' + do_darkmode_split(table_option_data) + ';';
  644. } else if(table_option_name === 'width') {
  645. data_option_all['td'] += 'width:' + do_px_add(table_option_data) + ';';
  646. } else if(table_option_name === 'height') {
  647. data_option_all['td'] += 'height:' + do_px_add(table_option_data) + ';';
  648. } else {
  649. no_option = '<lt>' + data_option + '<gt>';
  650. }
  651. } else {
  652. if(data_option.match(/^-[0-9]+$/)) {
  653. // span
  654. data_option_all['colspan'] = data_option.replace('-', '');
  655. } else if(data_option.match(/^(\^|v)?\|[0-9]+$/)) {
  656. if(data_option[0] === '^') {
  657. data_option_all['td'] += 'vertical-align: top;';
  658. } else if(data[1] === 'v') {
  659. data_option_all['td'] += 'vertical-align: bottom;';
  660. }
  661. data_option_all['rowspan'] = data_option.replace(/[^0-9]+/g, '');
  662. } else if(
  663. data_option === '(' ||
  664. data_option === ':' ||
  665. data_option === ')'
  666. ) {
  667. // align
  668. if(data_option === '(') {
  669. data_option_all['td'] += 'text-align:right;';
  670. } else if(data_option === ':') {
  671. data_option_all['td'] += 'text-align:center;';
  672. } else {
  673. data_option_all['td'] += 'text-align:left;';
  674. }
  675. align_auto = 0;
  676. } else {
  677. var table_option_data = data_option.replace(/"/g, '').match(/^((?:#[a-zA-Z0-9]{3}){1,2}|\w+)/);
  678. if(table_option_data) {
  679. data_option_all['td'] += 'background:' + table_option_data[1] + ';';
  680. } else {
  681. no_option = '<lt>' + data_option + '<gt>';
  682. }
  683. }
  684. }
  685. data = data.replace(table_option_re, no_option);
  686. }
  687. data = data.replace('<lt>', '&lt;');
  688. data = data.replace('<gt>', '&gt;');
  689. data_option_all['data'] = data;
  690. if(align_auto === 1) {
  691. if(
  692. data_option_all['data'][0] === ' ' ||
  693. data_option_all['data'][data_option_all['data'].length - 1] === ' '
  694. ) {
  695. data_option_all['td'] += 'text-align:center;';
  696. } else if(data_option_all['data'][0] === ' ') {
  697. data_option_all['td'] += 'text-align:right;';
  698. }
  699. }
  700. data_option_all['data'] = data_option_all['data'].replace(/^ +| +$/g, '');
  701. return data_option_all;
  702. }
  703. function do_onmark_table_render(data) {
  704. var table_before_re = /\|\|((?:(?:(?:(?!\|\|).)+)\n)(?:(?:(?:(?!\|\|).)+)\n*)*)\|\|/;
  705. while(1) {
  706. if(data.match(table_before_re)) {
  707. data = data.replace(table_before_re, function(x, x_1) {
  708. return '||' + x_1.replace(/\n/g, '<t_br>') + '||';
  709. })
  710. } else {
  711. break;
  712. }
  713. }
  714. var table_re = /\n((?:(?:(?:\|\|)+)(?:(?:(?:(?!\|\|).)+)|\n))+)\|\|\n/g;
  715. var table_in_re = /(?:((?:\|\|)+)((?:(?:(?!\|\|).)+)|\n))/;
  716. data = data.replace(table_re, function(x, x_1) {
  717. var table_data_real = '';
  718. var table_data_var = x_1;
  719. var table_new_line = 0;
  720. var table_col = 0;
  721. var table_data_col = {};
  722. while(1) {
  723. var table_data_in = table_data_var.match(table_in_re);
  724. if(!table_data_in) {
  725. break;
  726. }
  727. if(!table_data_col[table_col]) {
  728. table_data_col[table_col] = '';
  729. }
  730. var table_data_option = do_onmark_table_render_sub(
  731. table_data_in[2],
  732. table_data_col[table_col]
  733. );
  734. table_data_col[table_col] = table_data_option['col'];
  735. if(table_data_option['colspan'] === "") {
  736. table_data_option['colspan'] = String(table_data_in[1].length / 2);
  737. }
  738. if(table_data_real === '') {
  739. table_data_real += '' +
  740. '<div style="' + table_data_option['div'] + '">' +
  741. '<table style="' + table_data_option['table'] + '">' +
  742. '<tr style="' + table_data_option['tr'] + '">' +
  743. '';
  744. }
  745. if(table_data_in[2] === '\n') {
  746. table_data_real += '</tr>';
  747. table_new_line = 1;
  748. table_col = 0;
  749. } else {
  750. if(table_new_line === 1) {
  751. table_data_real += '<tr style="' + table_data_option['tr'] + '">';
  752. table_new_line = 0;
  753. }
  754. table_data_real += '' +
  755. '<td colspan="' + table_data_option['colspan'] + '" ' +
  756. 'rowspan="' + table_data_option['rowspan'] + '" ' +
  757. 'style="' + table_data_option['col'] + table_data_option['td'] + '">' +
  758. table_data_option['data'] +
  759. '</td>' +
  760. '';
  761. table_col += 1;
  762. }
  763. table_data_var = table_data_var.replace(table_in_re, '');
  764. }
  765. table_data_real += '</tr></table></div>';
  766. return '\n' + table_data_real + '\n';
  767. });
  768. data = data.replace(/<t_br>/g, '\n');
  769. return data;
  770. }
  771. function do_onmark_list_render(data) {
  772. var list_re = /\n((?:(?:(?: )+)\* (?:(?:(?!\n).)+)\n)+)/;
  773. var list_short_re = /((?: )+)\* ((?:(?!\n).)+)\n/g;
  774. while(1) {
  775. var list_data = data.match(list_re);
  776. if(!list_data) {
  777. break;
  778. }
  779. var list_end_data = '<ul>' + list_data[1].replace(list_short_re, function(x, x_1, x_2) {
  780. return '<li style="margin-left: ' + String(x_1.length * 20) + 'px;">' + x_2 + '</li>';
  781. }) + '</ul>';
  782. data = data.replace(list_re, '\n<start_point>' + list_end_data + '<end_point>\n');
  783. }
  784. return data;
  785. }
  786. function do_onmark_math_render(data, data_js, name_include) {
  787. data = data.replace(/<math>((?:(?!<\/math>).)+)<\/math>/g, '[math($1)]');
  788. var i = 0;
  789. data = data.replace(/\[math\((((?!\)]).)+)\)]/g, function(x, x_1) {
  790. i += 1;
  791. data_js += do_math_try_insert(name_include + 'math_' + String(i), do_js_safe_change(do_xss_change(x_1)));
  792. return '<span id="' + name_include + 'math_' + String(i) + '"></span>';
  793. });
  794. return [data, data_js];
  795. }
  796. function do_onmark_quote_render(data) {
  797. data = data.replace(/(\n(?:&gt;(?:[^\n]+)\n)+)/g, function(x, x_1) {
  798. return '\n<start_point><blockquote>' + do_onmark_quote_render(x_1.replace(/\n&gt; */g, '\n')).replace(/^\n/, '') + '</blockquote><end_point>\n';
  799. });
  800. return data;
  801. }
  802. function do_onmark_hr_render(data) {
  803. var hr_re = /\n-{4,}\n/;
  804. while(1) {
  805. if(!data.match(hr_re)) {
  806. break;
  807. }
  808. data = data.replace(hr_re, '\n<start_point><hr><end_point>\n');
  809. }
  810. return data;
  811. }
  812. // Main
  813. function do_onmark_render(test_mode = 'test', name_id = '', name_include = '', name_doc = '', doc_data = '') {
  814. if(test_mode === 'normal') {
  815. var data = '\n' + document.getElementById(name_id).innerHTML.replace(/\r/g, '') + '\n';
  816. } else if(test_mode === 'manual') {
  817. var data = '\n' + doc_data.replace(/\r/g, '') + '\n';
  818. } else {
  819. var data = '\n' + (
  820. `||||<tablebgcolor=red><bgcolor=red> test ||
  821. || A || B ||
  822. ||<bgcolor=red> test ||<bgcolor=red> test || asdf
  823. asdf || asdf`
  824. ).replace(/\r/g, '') + '\n';
  825. }
  826. var data_js = '';
  827. var data_backlink = [];
  828. var data_nowiki = {};
  829. var data_var = do_onmark_math_render(data, data_js, name_include);
  830. data = data_var[0];
  831. data_js = data_var[1];
  832. console.log('math')
  833. data_var = do_onmark_nowiki_before_render(data, data_js, name_include, data_nowiki);
  834. data = data_var[0];
  835. data_js = data_var[1];
  836. data_nowiki = data_var[2];
  837. console.log('nowiki')
  838. data_var = do_onmark_include_render(data, data_js, name_include, data_nowiki);
  839. data = data_var[0];
  840. data_js = data_var[1];
  841. console.log('include')
  842. data_var = do_onmark_middle_render(data, data_js, name_include, data_nowiki, name_doc);
  843. data = data_var[0];
  844. data_js = data_var[1];
  845. data_nowiki = data_var[2];
  846. console.log('middle')
  847. data = do_onmark_text_render(data);
  848. data = do_onmark_heading_render(data, name_doc, name_include);
  849. data = do_onmark_table_render(data);
  850. console.log('table')
  851. data_var = do_onmark_link_render(data, data_js, name_doc, name_include, data_nowiki);
  852. data = data_var[0];
  853. data_js = data_var[1];
  854. data = do_onmark_macro_render(data);
  855. data = do_onmark_quote_render(data);
  856. data = do_onmark_list_render(data);
  857. data = do_onmark_hr_render(data);
  858. data = do_onmark_footnote_render(data, name_include);
  859. data = do_onmark_last_render(data, name_include);
  860. console.log('all')
  861. data_js += '' +
  862. 'get_link_state("' + name_include + '");\n' +
  863. 'get_file_state("' + name_include + '");\n' +
  864. ''
  865. data_js = 'render_html("' + name_include + 'render_contect");\n' + data_js
  866. if(test_mode === 'normal') {
  867. document.getElementById(name_id).innerHTML = data + '<script>' + data_js + '</script>';
  868. eval(data_js);
  869. } else if(test_mode === 'manual') {
  870. return [data, data_js];
  871. } else {
  872. console.log([data, data_js]);
  873. }
  874. }