render_onmark.js 37 KB

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