render_onmark.js 45 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170
  1. // 인터위키
  2. // 표 캡션
  3. // pagecount
  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) {
  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, '<sup>$1</sup>');
  79. data = data.replace(/,,,((?:(?!,,,).)+),,,/g, '<sub>$1</sub>');
  80. data = data.replace(/,,((?:(?!,,).)+),,/g, '<sub>$1</sub>');
  81. data = data.replace(/--((?:(?!--).)+)--/g, '<s>$1</s>');
  82. data = data.replace(/~~((?:(?!~~).)+)~~/g, '<s>$1</s>');
  83. return data;
  84. }
  85. function do_onmark_heading_render(data, name_doc, name_include) {
  86. var heading_re = /\n(={1,6})(#)? ?([^=]+) ?#?={1,6}\n/;
  87. var heading_level_all = [0, 0, 0, 0, 0, 0];
  88. var toc_data = '';
  89. var toc_n = 0;
  90. while(1) {
  91. toc_n += 1;
  92. var heading_data = data.match(heading_re);
  93. if(!heading_data) {
  94. break;
  95. }
  96. if(toc_data === '') {
  97. toc_data += '<div id="toc"><div id="toc_title">TOC</div>\n';
  98. }
  99. var heading_level = heading_data[1].length;
  100. heading_level_all[heading_level - 1] += 1;
  101. var i = 6;
  102. while(i > heading_level - 1) {
  103. heading_level_all[i] = 0;
  104. i -= 1;
  105. }
  106. heading_level = String(heading_level);
  107. var heading_level_string = '';
  108. i = 0;
  109. while(i < 6) {
  110. if(heading_level_all[i] !== 0) {
  111. heading_level_string += String(heading_level_all[i]) + '.';
  112. }
  113. i += 1;
  114. }
  115. var heading_level_string_no_end = heading_level_string.replace(/\.$/, '');
  116. var heading_data_text = heading_data[3].replace(/ #$/, '');
  117. toc_data += '' +
  118. '<span style="margin-left: ' + String((heading_level_string.match(/\./g).length - 1) * 10) + 'px;">' +
  119. '<a href="#s-' + heading_level_string_no_end + '">' +
  120. heading_level_string + ' ' +
  121. '</a>' + heading_data_text +
  122. '</span>' +
  123. '\n' +
  124. ''
  125. data = data.replace(heading_re,
  126. '\n<start_point>' +
  127. (toc_n === 1 ? '' : '</div>') +
  128. '<h' + heading_level + ' id="s-' + heading_level_string_no_end + '">' +
  129. '<a href="#toc">' + heading_level_string + '</a> ' +
  130. heading_data_text +
  131. '<a id="edit_load_' + String(toc_n) + '" ' +
  132. 'style="font-size: 70%;"' +
  133. 'href="/edit/' + do_url_change(name_doc) + '?section=' + String(toc_n) + '">✎</a> ' +
  134. '<a href="javascript:void(0);" ' +
  135. 'onclick="javascript:do_open_folding(\'' + name_include + 'in_data_' + String(toc_n) + '\', this);"' +
  136. 'style="font-size: 70%;">' + (heading_data[2] ? '⊕' : '⊖') + '</a>' +
  137. '</h' + heading_level + '>' +
  138. '<div id="' + name_include + 'in_data_' + String(toc_n) + '" ' +
  139. 'style="display: ' + (heading_data[2] ? 'none' : 'block') + ';">' +
  140. '<end_point>\n'
  141. );
  142. }
  143. if(toc_data !== '') {
  144. toc_data += '</div>';
  145. data += '</div>';
  146. }
  147. var toc_auto_add = data.match(/\[(?:목차|toc)\(no\)\]/);
  148. var toc_re = /\[(?:toc|목차)\]/g;
  149. if(toc_auto_add) {
  150. data = data.replace(/\[(?:목차|toc)\(no\)\]/g, '');
  151. } else {
  152. if(name_include === '' && !data.match(toc_re)) {
  153. data = data.replace(/(<h[1-6] (?:[^>]+)>)/, '<div id="auto_toc">' + toc_data + '</div>$1');
  154. }
  155. }
  156. data = data.replace(toc_re, toc_data);
  157. return data;
  158. }
  159. function do_onmark_link_render(data, data_js, name_doc, name_include, data_nowiki) {
  160. var num_link = 0;
  161. var category_data = '';
  162. var category_re = /^(분류|category):/i;
  163. var file_re = /^(파일|file|외부|out):/i;
  164. var link_re = /\[\[(((?!\[\[|\]\]).)+)\]\]/;
  165. while(data.match(link_re)) {
  166. data = data.replace(link_re, function(x, x_1) {
  167. var link_split = x_1.split('|');
  168. var link_real = link_split[0];
  169. var link_out = link_split[1] ? link_split[1] : link_split[0];
  170. var link_out_2 = link_split[1] ? link_split[1] : '';
  171. num_link += 1;
  172. var num_link_str = String(num_link - 1);
  173. if(link_real.match(file_re)) {
  174. var file_load_type = link_real.match(file_re)[1];
  175. var file_name = link_real.replace(file_re, '');
  176. if(file_load_type === '파일' || file_load_type === 'file') {
  177. var file_type = file_name.split('.');
  178. file_name = file_type.slice(0, file_type.length - 1).join('.');
  179. file_type = file_type[file_type.length - 1];
  180. var file_src = do_url_change(file_name) + '.' + file_type;
  181. var file_alt = file_name + '.' + file_type;
  182. var file_exist = 1;
  183. } else {
  184. var file_src = file_name;
  185. var file_alt = file_name;
  186. var file_exist = 0;
  187. }
  188. var file_style = '';
  189. var file_bgcolor = '';
  190. var file_align = '';
  191. var file_set = link_out_2.split('&amp;');
  192. var i = 0;
  193. while(file_set[i]) {
  194. var file_set_name = file_set[i].split('=');
  195. var file_set_data = file_set_name[1];
  196. file_set_name = file_set_name[0];
  197. if(file_set_name === 'width') {
  198. file_style += 'width:' + file_set_data + ';';
  199. } else if(file_set_name === 'height') {
  200. file_style += 'height:' + file_set_data + ';';
  201. } else if(file_set_name === 'bgcolor') {
  202. file_bgcolor += 'background:' + file_set_data + ';';
  203. } else if(file_set_name === 'alt') {
  204. file_alt += file_set_data;
  205. } else if(file_set_name === 'align') {
  206. if(file_set_data === 'center') {
  207. file_align = 'display: block; text-align: center;';
  208. } else {
  209. file_align = 'float: ' + file_set_data + ';';
  210. }
  211. }
  212. i += 1;
  213. }
  214. return '' +
  215. '<span style="' + file_align + '">' +
  216. '<span style="' + file_bgcolor + '" ' +
  217. 'class="' + name_include + 'file_finder" ' +
  218. 'under_style="' + file_style + '" ' +
  219. 'under_alt="' + file_alt + '" ' +
  220. 'under_src="' + file_src + '" ' +
  221. 'under_href="' + (file_exist === 0 ? "out_link" : '/upload?name=' + do_url_change(file_name)) + '">' +
  222. '</span>' +
  223. '</span>' +
  224. ''
  225. } else if(link_real.match(category_re)) {
  226. var category_link = link_real.replace(category_re, '');
  227. category_data = (category_data === '' ? '<div id="cate_all"><div id="cate">Category : ' : category_data);
  228. category_data += '' +
  229. '<a class="' + name_include + 'link_finder" ' +
  230. 'href="/w/category:' + do_url_change(category_link) + '">' +
  231. category_link +
  232. '</a> | ' +
  233. ''
  234. return '';
  235. } else if(link_real.match(/^http(s)?:\/\//)) {
  236. var i = 0;
  237. while(i < 2) {
  238. if(i === 0) {
  239. var var_link_type = 'href';
  240. } else {
  241. var var_link_type = 'title';
  242. }
  243. data_js += '' +
  244. 'document.getElementsByName("' + name_include + 'set_link_' + num_link_str + '")[0].' + var_link_type + ' = ' +
  245. '"' + do_js_safe_change(do_xss_change(link_real)) + '";' +
  246. '\n' +
  247. '';
  248. i += 1;
  249. }
  250. return '<a id="out_link" ' +
  251. 'name="' + name_include + 'set_link_' + num_link_str + '" ' +
  252. 'title=""' +
  253. 'href="">' + link_out + '</a>';
  254. } else {
  255. if(link_real.match(/^\//)) {
  256. link_real = name_doc + link_real;
  257. } else if(link_real.match(/^\.\.\//)) {
  258. link_real = link_real.replace(/^\.\.\//, '');
  259. link_real = name_doc.replace(/\/[^/]+$/, '') + (link_real !== '' ? '/' + link_real : '');
  260. }
  261. var i = 0;
  262. while(i < 2) {
  263. if(i === 0) {
  264. var link_data_var = do_link_change(link_real, data_nowiki, 0);
  265. var link_main = link_data_var[0];
  266. var link_sub = link_data_var[1];
  267. var var_link_type = 'href';
  268. if(link_main === '') {
  269. var var_link_data = link_sub;
  270. } else {
  271. var var_link_data = '/w/' + do_url_change(link_main) + link_sub;
  272. }
  273. } else {
  274. var var_link_type = 'title';
  275. var var_link_data = do_js_safe_change(link_main) + link_sub;
  276. }
  277. data_js += '' +
  278. 'document.getElementsByName("' + name_include + 'set_link_' + num_link_str + '")[0].' + var_link_type + ' = ' +
  279. '"' + var_link_data + '";' +
  280. '\n' +
  281. '';
  282. i += 1;
  283. }
  284. return '<a class="' + name_include + 'link_finder" ' +
  285. 'name="' + name_include + 'set_link_' + num_link_str + '" ' +
  286. 'title="" ' +
  287. 'href="">' + link_out + '</a>';
  288. }
  289. });
  290. }
  291. if(name_include === '') {
  292. data += (category_data === '' ? '' : (category_data.replace(/\| $/, '') + '</div></div>'));
  293. }
  294. return [data, data_js];
  295. }
  296. function do_onmark_footnote_render(data, name_include) {
  297. var footnote_end_data = '';
  298. var footnote_all_data = {};
  299. var footnote_re = /(?:\[\*([^ \]]*)(?: ((?:(?!\]).)+))?\]|\[(footnote|각주)\])/;
  300. var i = 1;
  301. while(1) {
  302. var footnote_data = data.match(footnote_re);
  303. if(!footnote_data) {
  304. break;
  305. }
  306. if(!footnote_data[3]) {
  307. if(!footnote_data[2]) {
  308. var footnote_line_data = '';
  309. } else {
  310. var footnote_line_data = footnote_data[2];
  311. }
  312. if(!footnote_data[1]) {
  313. var footnote_name = String(i);
  314. } else {
  315. var footnote_name = footnote_data[1];
  316. }
  317. if(!footnote_all_data[footnote_name]) {
  318. footnote_all_data[footnote_name] = footnote_line_data;
  319. }
  320. footnote_line_data = footnote_all_data[footnote_name];
  321. footnote_end_data += '' +
  322. '<li>' +
  323. '<a href="javascript:do_open_foot(\'' + name_include + 'fn-' + String(i) + '\', 1);" ' +
  324. 'id="' + name_include + 'cfn-' + String(i) + '">' +
  325. '(' + footnote_name + ')' +
  326. '</a> <span id="' + name_include + 'fn-' + String(i) + '">' + footnote_line_data + '</span>' +
  327. '</li>' +
  328. '';
  329. data = data.replace(footnote_re, '' +
  330. '<sup>' +
  331. '<a href="javascript:do_open_foot(\'' + name_include + 'fn-' + String(i) + '\', 0);" ' +
  332. 'id="' + name_include + 'rfn-' + String(i) + '">' +
  333. '(' + footnote_name + ')' +
  334. '</a>' +
  335. '</sup><span id="' + name_include + 'dfn-' + String(i) + '"></span>' +
  336. '');
  337. i += 1;
  338. } else {
  339. if(footnote_end_data !== '') {
  340. footnote_end_data = '<ul id="footnote_data">' + footnote_end_data + '</ul>';
  341. }
  342. data = data.replace(footnote_re, footnote_end_data);
  343. footnote_end_data = '';
  344. }
  345. }
  346. if(name_include === '' && footnote_end_data !== '') {
  347. data += '<ul id="footnote_data">' + footnote_end_data + '</ul>';
  348. }
  349. return data;
  350. }
  351. function do_onmark_macro_render(data, data_js) {
  352. data = data.replace(/\[([^[\](]+)\(((?:(?!\)\]).)+)\)\]/g, function(x, x_1, x_2) {
  353. x_1 = x_1.toLowerCase();
  354. if(x_1 === 'youtube' || x_1 === 'kakaotv' || x_1 === 'nicovideo') {
  355. var video_code = x_2.match(/^([^,]+)/);
  356. video_code = video_code ? video_code[1] : '';
  357. var video_width = x_2.match(/,(?: *)width=([0-9]+)/);
  358. video_width = video_width ? (video_width[1] + 'px') : '640px';
  359. var video_height = x_2.match(/,(?: *)height=([0-9]+)/);
  360. video_height = video_height ? (video_height[1] + 'px') : '360px';
  361. if(x_1 === 'youtube') {
  362. var video_start = x_2.match(/,(?: *)start=([0-9]+)/);
  363. video_start = video_start ? ('?' + video_start[1]) : '';
  364. video_code = video_code.replace(/^https:\/\/www\.youtube\.com\/watch\?v=/, '');
  365. video_code = video_code.replace(/^https:\/\/youtu\.be\//, '');
  366. var video_src = 'https://www.youtube.com/embed/' + video_code + video_start
  367. } else if(x_1 === 'kakaotv') {
  368. video_code = video_code.replace(/^https:\/\/tv\.kakao\.com\/channel\/9262\/cliplink\//, '');
  369. video_code = video_code.replace(/^http:\/\/tv\.kakao\.com\/v\//, '');
  370. var video_src = 'https://tv.kakao.com/embed/player/cliplink/' + video_code +'?service=kakao_tv'
  371. } else {
  372. var video_src = 'https://embed.nicovideo.jp/watch/' + video_code
  373. }
  374. return '<iframe style="width: ' + video_width + '; height: ' + video_height + ';" src="' + video_src + '" frameborder="0" allowfullscreen></iframe>';
  375. } else if(x_1 === 'anchor') {
  376. return '<span id="' + x_2 + '"></span>';
  377. } else if(x_1 === 'dday') {
  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) / (24 * 60 * 60 * 1000));
  381. return date_end > 0 ? '+' + date_end : '-' + date_end;
  382. } else if(x_1 === 'age') {
  383. var date_old = new Date(x_2);
  384. var date_now = new Date(do_return_date());
  385. var date_end = Math.floor((date_now - date_old) / (365 * 24 * 60 * 60 * 1000));
  386. return date_end > 0 ? date_end : '';
  387. } else if(x_1 === 'pagecount') {
  388. return '0';
  389. } else {
  390. return '<macro_start>' + x_1 + '(' + x_2 + ')<macro_end>';
  391. }
  392. });
  393. var pagecount_n = 0;
  394. data = data.replace(/\[([^[*()\]]+)\]/g, function(x, x_1) {
  395. x_1 = x_1.toLowerCase();
  396. if(x_1 === 'date') {
  397. return do_return_date();
  398. } else if(x_1 === 'clearfix') {
  399. return '<div style="clear:both"></div>';
  400. } else if(x_1 === 'br') {
  401. return '<br>';
  402. } else if(x_1 === 'pagecount') {
  403. if(pagecount_n === 0) {
  404. pagecount_n += 1;
  405. data_js += 'page_count();\n';
  406. }
  407. return '<span class="all_page_count"></span>';
  408. } else {
  409. return '<macro_start>' + x_1 + '<macro_end>';
  410. }
  411. });
  412. data = data.replace(/<macro_start>/g, '[');
  413. data = data.replace(/<macro_end>/g, ']');
  414. return [data, data_js];
  415. }
  416. function do_onmark_middle_render(data, data_js, name_include, data_nowiki, name_doc) {
  417. var middle_re = /{{{((?:(?!{{{|}}}).)+)}}}/s;
  418. var html_n = 0;
  419. var syntax_n = 0;
  420. var nowiki_n = 0;
  421. var folding_n = 0;
  422. while(data.match(middle_re)) {
  423. data = data.replace(middle_re, function(x, x_1) {
  424. var middle_data_before = x_1.match(/^({+)/);
  425. middle_data_before = middle_data_before ? middle_data_before[1] : '';
  426. var middle_data_x_1 = x_1.replace(/^({+)/, '');
  427. var middle_data = middle_data_x_1.match(/^([^ ]+) /);
  428. middle_data = middle_data ? middle_data[1] : '';
  429. if(middle_data) {
  430. var middle_data_all = middle_data_x_1.replace(/^([^ ]+) /, '');
  431. }
  432. var middle_type = middle_data.match(
  433. /^(?:(?:(?:(#|@)((?:[0-9a-f-A-F]{3}){1,2}))(?:,(?:#|@)(?:(?:[0-9a-f-A-F]{3}){1,2}))?|(#|@)([a-zA-Z]+))|(\+|-)([1-5])|#!(html|wiki|syntax|folding|html))$/i
  434. );
  435. if(middle_type) {
  436. if(middle_data_x_1[middle_data_x_1.length - 1] === '\\') {
  437. return middle_data_before + '{{{' + middle_data_x_1 + '<mid_e>';
  438. } else if(middle_type[1]) {
  439. if(middle_type[1] === '@') {
  440. return middle_data_before + '<span style="background: #' + middle_type[2] + '">' + middle_data_all + '</span>';
  441. } else {
  442. return middle_data_before + '<span style="color: #' + middle_type[2] + '">' + middle_data_all + '</span>';
  443. }
  444. } else if(middle_type[3]) {
  445. if(middle_type[3] === '@') {
  446. return middle_data_before + '<span style="background: ' + middle_type[4] + '">' + middle_data_all + '</span>';
  447. } else {
  448. return middle_data_before + '<span style="color: ' + middle_type[4] + '">' + middle_data_all + '</span>';
  449. }
  450. } else if(middle_type[5]) {
  451. if(middle_type[5] === '+') {
  452. return middle_data_before + '<span style="font-size: ' + String(100 + (Number(middle_type[6]) * 20)) + '%">' + middle_data_all + '</span>';
  453. } else {
  454. return middle_data_before + '<span style="font-size: ' + String(100 - (Number(middle_type[6]) * 10)) + '%">' + middle_data_all + '</span>';
  455. }
  456. } else if(middle_type[7]) {
  457. var middle_type_sub = middle_type[7].toLowerCase();
  458. if(middle_type_sub === 'html') {
  459. html_n += 1;
  460. data_nowiki[name_include + 'nowiki_html_' + String(html_n)] = middle_data_all;
  461. data_js += do_data_try_insert(
  462. name_include + 'nowiki_html_' + String(html_n),
  463. do_js_safe_change(middle_data_all)
  464. );
  465. return middle_data_before + '<span id="' + name_include + 'nowiki_html_' + String(html_n) + '"></span>';
  466. } else if(middle_type_sub === 'wiki') {
  467. var middle_wiki_re = /^(?:[^ ]+)(?: style=['"]([^\n'"]*)['"])?\n?/;
  468. var middle_wiki = middle_data_x_1.match(middle_wiki_re);
  469. middle_wiki = middle_wiki[1] ? middle_wiki[1] : '';
  470. middle_wiki = middle_wiki.replace(/display/, '');
  471. middle_data_all = middle_data_x_1.replace(middle_wiki_re, '');
  472. return middle_data_before + '' +
  473. '<wiki_s style="' + middle_wiki + '">' +
  474. '<end_point>\n' +
  475. middle_data_all +
  476. '\n<start_point>' +
  477. '<wiki_e>' +
  478. '';
  479. } else if(middle_type_sub === 'folding') {
  480. folding_n += 1;
  481. var middle_folding_re = /^(?:[^ ]+)(?: ([^\n]*))?\n?/;
  482. var middle_folding = middle_data_x_1.match(middle_folding_re);
  483. middle_folding = middle_folding ? middle_folding[1] : 'open';
  484. middle_data_all = middle_data_x_1.replace(middle_folding_re, '');
  485. data_js += do_data_try_insert('get_' + name_include + 'folding_' + String(folding_n), do_js_safe_change(middle_folding));
  486. return middle_data_before +
  487. '<div>' +
  488. '<b>' +
  489. '<a href="javascript:do_open_folding(\'' + name_include + 'folding_' + String(folding_n) + '\');" ' +
  490. 'id="get_' + name_include + 'folding_' + String(folding_n) + '">' +
  491. '</a>' +
  492. '</b>' +
  493. '<div id="' + name_include + 'folding_' + String(folding_n) + '" style="display: none;">' +
  494. '<wiki_s style="">' +
  495. '\n' +
  496. middle_data_all +
  497. '\n<start_point>' +
  498. '<wiki_e>' +
  499. '</div>' +
  500. '</div>' +
  501. ''
  502. } else if(middle_type_sub === 'syntax') {
  503. syntax_n += 1;
  504. var middle_syntax = middle_data_x_1.match(/^(?:[^ ]+) ([^\n]+)\n/);
  505. middle_syntax = middle_syntax ? middle_syntax[1] : 'python';
  506. middle_data_all = middle_data_x_1.replace(/^(?:[^ ]+) ([^\n]+)\n/, '');
  507. data_nowiki[name_include + 'nowiki_syntax_' + String(syntax_n)] = middle_data_all;
  508. data_js += do_data_try_insert(
  509. name_include + 'nowiki_syntax_' + String(syntax_n),
  510. do_js_safe_change(middle_data_all)
  511. );
  512. return middle_data_before +
  513. '<pre id="syntax">' +
  514. '<code id="' + name_include + 'nowiki_syntax_' + String(syntax_n) + '" ' +
  515. 'class="' + middle_syntax + '"></code>' +
  516. '</pre>' +
  517. ''
  518. }
  519. }
  520. }
  521. // 최대한 노력해봐야함
  522. nowiki_n += 1;
  523. data_nowiki[name_include + 'nowiki_' + String(nowiki_n)] = middle_data_x_1;
  524. data_js = do_data_try_insert(
  525. name_include + 'nowiki_' + String(nowiki_n),
  526. do_js_safe_change(middle_data_x_1)
  527. ) + data_js;
  528. return middle_data_before + '<span id="' + name_include + 'nowiki_' + String(nowiki_n) + '"></span>';
  529. });
  530. }
  531. data = data.replace(/<mid_s>/g, '{{{');
  532. data = data.replace(/<mid_e>/g, '}}}');
  533. if(syntax_n > 0) {
  534. data_js += 'hljs.initHighlightingOnLoad();\n';
  535. }
  536. return [data, data_js, data_nowiki];
  537. }
  538. function do_onmark_last_render(data) {
  539. // middle_render 마지막 처리
  540. data = data.replace(/<wiki_s_[0-9] /g, '<div ');
  541. data = data.replace(/<wiki_e_[0-9]>/g, '</div>');
  542. // heading_render 마지막 처리
  543. data = data.replace(/\n?<start_point>/g, '');
  544. data = data.replace(/<end_point>\n?/g, '');
  545. // br 마지막 처리
  546. data = data.replace(/^(\n| )+/, '');
  547. data = data.replace(/(\n| )+$/, '');
  548. data = data.replace(/\n/g, '<br>');
  549. return data;
  550. }
  551. function do_onmark_include_render(data, data_js, name_include, data_nowiki) {
  552. var include_re = /\[include\(((?:(?!\)\]).)+)\)\]/i;
  553. var i = 0;
  554. while(1) {
  555. i += 1;
  556. var include_data = data.match(include_re);
  557. if(!include_data) {
  558. break;
  559. }
  560. var include_name = do_nowiki_change(
  561. include_data[1].match(/^([^,]+)/)[1],
  562. data_nowiki
  563. );
  564. var include_add_re = /, *([^=]+)=((?:(?:(?!\)]|,).)+)+)/;
  565. var include_add_data = []
  566. var include_data = include_data[1];
  567. while(1) {
  568. var include_add = include_data.match(include_add_re);
  569. if(!include_add) {
  570. break;
  571. }
  572. include_add_data.push([
  573. include_add[1],
  574. do_nowiki_change(include_add[2], data_nowiki)
  575. ]);
  576. include_data = include_data.replace(include_add_re, '');
  577. }
  578. data = data.replace(include_re,
  579. '<a id="' + name_include + 'include_link" class="include_' + String(i) + '" href="">(' + include_name + ')</a>' +
  580. '<div id="' + name_include + 'include_' + String(i) + '"></div>'
  581. );
  582. data_js += 'load_include("' + do_js_safe_change(include_name) + '", "' + name_include + 'include_' + String(i) + '", ' + JSON.stringify(include_add_data) + ');\n'
  583. }
  584. return [data, data_js];
  585. }
  586. function do_onmark_nowiki_before_render(data, data_js, name_include, data_nowiki) {
  587. var num_nowiki = 0;
  588. data = data.replace(/\\(.)/g, function(x, x_1) {
  589. num_nowiki += 1;
  590. data_nowiki[name_include + 'nowiki_one_' + String(num_nowiki)] = x_1;
  591. data_js += do_data_try_insert(name_include + 'nowiki_one_' + String(num_nowiki), do_js_safe_change(x_1));
  592. return '<span id="' + name_include + 'nowiki_one_' + String(num_nowiki) + '"></span>';
  593. });
  594. return [data, data_js, data_nowiki, num_nowiki];
  595. }
  596. function do_onmark_table_render_sub(data, data_col) {
  597. var data_option_all = {
  598. "div" : "",
  599. "table" : "",
  600. "tr" : "",
  601. "td" : "",
  602. "col" : data_col,
  603. "colspan" : "",
  604. "rowspan" : "",
  605. "data" : ""
  606. };
  607. var table_option_re = /&lt;((?:(?!&lt;|&gt;).)+)&gt;/;
  608. while(1) {
  609. var no_option = '';
  610. var align_auto = 1;
  611. var data_option = data.match(table_option_re);
  612. if(!data_option) {
  613. break;
  614. }
  615. data_option = data_option[1];
  616. var data_option_var = data_option.split('=');
  617. if(data_option_var.length === 2) {
  618. var table_option_name = data_option_var[0].replace(/ /g, '');
  619. var table_option_data = data_option_var[1].replace(/"/g, '');
  620. if(table_option_name === 'tablebgcolor') {
  621. // table
  622. data_option_all['table'] += 'background:' + do_darkmode_split(table_option_data) + ';';
  623. } else if(table_option_name === 'tablewidth') {
  624. data_option_all['table'] += 'width:' + do_px_add(table_option_data) + ';';
  625. } else if(table_option_name === 'tableheight') {
  626. data_option_all['table'] += 'height:' + do_px_add(table_option_data) + ';';
  627. } else if(table_option_name === 'tablealign') {
  628. if(table_option_data === 'right') {
  629. data_option_all['div'] += 'float:right;';
  630. } else if(table_option_data === 'center') {
  631. data_option_all['div'] += 'margin:auto;';
  632. data_option_all['table'] += 'margin:auto;';
  633. }
  634. } else if(table_option_name === 'tabletextalign') {
  635. data_option_all['table'] += 'text-align:' + table_option_data + ';';
  636. } else if(table_option_name === 'tablecolor') {
  637. data_option_all['table'] += 'color:' + do_darkmode_split(table_option_data) + ';';
  638. } else if(table_option_name === 'tablebordercolor') {
  639. data_option_all['table'] += 'border:2px solid ' + do_darkmode_split(table_option_data) + ';';
  640. } else if(table_option_name === 'rowbgcolor') {
  641. // tr
  642. data_option_all['tr'] += 'background:' + do_darkmode_split(table_option_data) + ';';
  643. } else if(table_option_name === 'rowtextalign') {
  644. data_option_all['tr'] += 'text-align:' + table_option_data + ';';
  645. } else if(table_option_name === 'rowcolor') {
  646. data_option_all['tr'] += 'color:' + do_darkmode_split(table_option_data) + ';';
  647. } else if(table_option_name === 'colcolor') {
  648. // col
  649. data_option_all['col'] += 'color:' + do_darkmode_split(table_option_data) + ';';
  650. } else if(table_option_name === 'colbgcolor') {
  651. data_option_all['col'] += 'background:' + do_darkmode_split(table_option_data) + ';';
  652. } else if(table_option_name === 'bgcolor') {
  653. // td
  654. data_option_all['td'] += 'background:' + do_darkmode_split(table_option_data) + ';';
  655. } else if(table_option_name === 'color') {
  656. data_option_all['td'] += 'color:' + do_darkmode_split(table_option_data) + ';';
  657. } else if(table_option_name === 'width') {
  658. data_option_all['td'] += 'width:' + do_px_add(table_option_data) + ';';
  659. } else if(table_option_name === 'height') {
  660. data_option_all['td'] += 'height:' + do_px_add(table_option_data) + ';';
  661. } else {
  662. no_option = '<lt>' + data_option + '<gt>';
  663. }
  664. } else {
  665. if(data_option.match(/^-[0-9]+$/)) {
  666. // span
  667. data_option_all['colspan'] = data_option.replace('-', '');
  668. } else if(data_option.match(/^(\^|v)?\|[0-9]+$/)) {
  669. if(data_option[0] === '^') {
  670. data_option_all['td'] += 'vertical-align: top;';
  671. } else if(data_option[0] === 'v') {
  672. data_option_all['td'] += 'vertical-align: bottom;';
  673. }
  674. data_option_all['rowspan'] = data_option.replace(/[^0-9]+/g, '');
  675. } else if(
  676. data_option === '(' ||
  677. data_option === ':' ||
  678. data_option === ')'
  679. ) {
  680. // align
  681. if(data_option === '(') {
  682. data_option_all['td'] += 'text-align:right;';
  683. } else if(data_option === ':') {
  684. data_option_all['td'] += 'text-align:center;';
  685. } else {
  686. data_option_all['td'] += 'text-align:left;';
  687. }
  688. align_auto = 0;
  689. } else {
  690. var table_option_data = data_option.replace(/"/g, '').match(/^((?:#[a-zA-Z0-9]{3}){1,2}|\w+)/);
  691. if(table_option_data) {
  692. data_option_all['td'] += 'background:' + table_option_data[1] + ';';
  693. } else {
  694. no_option = '<lt>' + data_option + '<gt>';
  695. }
  696. }
  697. }
  698. data = data.replace(table_option_re, no_option);
  699. }
  700. data = data.replace('<lt>', '&lt;');
  701. data = data.replace('<gt>', '&gt;');
  702. data_option_all['data'] = data;
  703. if(align_auto === 1) {
  704. if(
  705. data_option_all['data'][0] === ' ' ||
  706. data_option_all['data'][data_option_all['data'].length - 1] === ' '
  707. ) {
  708. data_option_all['td'] += 'text-align:center;';
  709. } else if(data_option_all['data'][0] === ' ') {
  710. data_option_all['td'] += 'text-align:right;';
  711. }
  712. }
  713. data_option_all['data'] = data_option_all['data'].replace(/^ +| +$/g, '');
  714. return data_option_all;
  715. }
  716. function do_onmark_table_render_main(data) {
  717. var table_re = /\n((?:(?:\|\||\|\|\n|(?:\|\|)+(?!\n)(?:(?:(?!\|\|).)+))+)\|\|)\n/gs;
  718. data = data.replace(table_re, function(x, x_1) {
  719. var table_cel_re = /((?:\|\|)+)((?:(?!\|\|).)*)/gs;
  720. var table_data = '';
  721. var table_data_org = x_1;
  722. var table_col = 0;
  723. var table_col_data = {};
  724. var table_col_count = {};
  725. table_data_org = table_data_org.replace(table_cel_re, function(x, x_1, x_2) {
  726. if(!table_col_data[table_col]) {
  727. table_col_data[table_col] = '';
  728. }
  729. if(!table_col_count[table_col]) {
  730. table_col_count[table_col] = 0;
  731. }
  732. if(table_col_count[table_col] !== 0) {
  733. table_col_count[table_col] -= 1;
  734. table_col += 1;
  735. }
  736. var table_data_option = do_onmark_table_render_sub(x_2, table_col_data[table_col]);
  737. table_col_data[table_col] = table_data_option['col'];
  738. if(table_data_option['colspan'] === '') {
  739. table_data_option['colspan'] = String(x_1.length / 2);
  740. }
  741. if(table_data === '') {
  742. table_data += '' +
  743. '<div style="' + table_data_option['div'] + '">' +
  744. '<table style="' + table_data_option['table'] + '">' +
  745. '';
  746. }
  747. if(x_1 === '||' && (x_2 === '\n' || x_2 === '')) {
  748. table_data += '</tr>';
  749. table_col = 0;
  750. } else if(x_2 === '\n' || x_2 === '') {
  751. table_data += '</tr><tr></tr>';
  752. table_col = 0;
  753. } else {
  754. if(table_col === 0) {
  755. table_data += '' +
  756. '<tr style="' + table_data_option['tr'] + '">' +
  757. ''
  758. }
  759. if(table_data_option['rowspan'] !== '') {
  760. table_col_count[table_col] += Number(table_data_option['rowspan']) - 1;
  761. }
  762. table_data += '' +
  763. '<td colspan="' + table_data_option['colspan'] + '" ' +
  764. 'rowspan="' + table_data_option['rowspan'] + '" ' +
  765. 'style="' + table_data_option['col'] + table_data_option['td'] + '">' +
  766. table_data_option['data'] +
  767. '</td>' +
  768. '';
  769. table_col += 1;
  770. }
  771. return '';
  772. });
  773. if(table_col === 0) {
  774. table_data += '</table></div>';
  775. } else {
  776. table_data += '</tr></table></div>';
  777. }
  778. return '\n' + table_data + '\n';
  779. });
  780. return data;
  781. }
  782. function do_onmark_table_render(data) {
  783. data = data.replace(/ +\|\|/g, '||');
  784. var wiki_re = /<wiki_s ([^>]+)>((?:(?!<wiki_s |<wiki_e>).)+)<wiki_e>/s;
  785. while(1) {
  786. if(!data.match(wiki_re)) {
  787. break;
  788. }
  789. data = data.replace(wiki_re, function(x, x_1, x_2) {
  790. return '<wiki_s_2 ' + x_1 + '>' + do_onmark_table_render_main(x_2) + '</wiki_e_2>';
  791. });
  792. }
  793. data = do_onmark_table_render_main(data);
  794. return data;
  795. }
  796. function do_onmark_list_render(data) {
  797. var wiki_re = /<wiki_s_2 ([^>]+)>((?:(?!<wiki_s_2 |<wiki_e_2>).)+)<wiki_e_2>/s;
  798. while(1) {
  799. if(!data.match(wiki_re)) {
  800. break;
  801. }
  802. data = data.replace(wiki_re, function(x, x_1, x_2) {
  803. return '<wiki_s_3 ' + x_1 + '>' + x_2.replace(/\n/g, '<t_br>') + '<wiki_e_3>';
  804. });
  805. }
  806. var quote_re = /\n((?:(?:(?:&gt;)+) ?(?:(?:(?!\n).)+)\n)+)/;
  807. var quote_short_re = /((?:&gt;)+) ?((?:(?!\n).)+)\n/g;
  808. var quote_leng = 1;
  809. while(1) {
  810. var quote_data = data.match(quote_re);
  811. if(!quote_data) {
  812. break;
  813. }
  814. var quote_end_data = quote_data[1].replace(quote_short_re, function(x, x_1, x_2) {
  815. var quote_leng_now = (x_1.length / 4);
  816. var quote_data_part_1 = '';
  817. var quote_data_part_2 = '';
  818. if(quote_leng < quote_leng_now) {
  819. var quote_data_part_1 = ('<blockquote><end_point>\n'.repeat(quote_leng_now - quote_leng));
  820. } else if(quote_leng > quote_leng_now) {
  821. var quote_data_part_1 = ('\n<start_point></blockquote>'.repeat(quote_leng - quote_leng_now));
  822. }
  823. quote_leng = quote_leng_now;
  824. return '' +
  825. quote_data_part_1 +
  826. x_2 + '\n'
  827. quote_data_part_2 +
  828. '';
  829. });
  830. data = data.replace(quote_re, '' +
  831. '<blockquote>' +
  832. '<end_point>\n' +
  833. quote_end_data +
  834. '\n<start_point>' +
  835. '</blockquote>' +
  836. '');
  837. }
  838. var list_re = /\n((?:(?:(?: )*)\* ?(?:(?:(?!\n).)+)\n)+)/;
  839. var list_short_re = /((?: )*)\* ?((?:(?!\n).)+)\n/g;
  840. while(1) {
  841. var list_data = data.match(list_re);
  842. if(!list_data) {
  843. break;
  844. }
  845. var list_end_data = list_data[1].replace(list_short_re, function(x, x_1, x_2) {
  846. var list_leng = x_1.length;
  847. list_leng = list_leng > 0 ? list_leng : 1;
  848. return '<li style="margin-left: ' + String((list_leng - 1) * 20) + 'px">' + x_2 + '</li>';
  849. });
  850. data = data.replace(list_re, '\n<start_point><ul>' + list_end_data + '</ul><end_point>\n');
  851. }
  852. var wiki_re = /<wiki_s_3 ([^>]+)>((?:(?!<wiki_s_3 |<wiki_e_3>).)+)<wiki_e_3>/s;
  853. while(1) {
  854. if(!data.match(wiki_re)) {
  855. break;
  856. }
  857. data = data.replace(wiki_re, function(x, x_1, x_2) {
  858. return '<wiki_s_4 ' + x_1 + '>' + x_2.replace(/<t_br>/g, '\n') + '<wiki_e_4>';
  859. });
  860. }
  861. return data;
  862. }
  863. function do_onmark_math_render(data, data_js, name_include) {
  864. data = data.replace(/<math>((?:(?!<\/math>).)+)<\/math>/g, '[math($1)]');
  865. var i = 0;
  866. data = data.replace(/\[math\((((?!\)]).)+)\)]/g, function(x, x_1) {
  867. i += 1;
  868. data_js += do_math_try_insert(name_include + 'math_' + String(i), do_js_safe_change(do_xss_change(x_1)));
  869. return '<span id="' + name_include + 'math_' + String(i) + '"></span>';
  870. });
  871. return [data, data_js];
  872. }
  873. function do_onmark_hr_render(data) {
  874. var hr_re = /\n-{4,9}\n/;
  875. while(1) {
  876. if(!data.match(hr_re)) {
  877. break;
  878. }
  879. data = data.replace(hr_re, '\n<start_point><hr><end_point>\n');
  880. }
  881. return data;
  882. }
  883. function do_onmark_redirect_render(data, data_js, name_doc) {
  884. var redirect_re = /^\n#(?:redirect|넘겨주기) ([^\n]+)/i;
  885. var data_redirect = data.match(redirect_re);
  886. if(data_redirect) {
  887. var link_data_var = do_link_change(data_redirect[1], {}, 1);
  888. var link_main = link_data_var[0];
  889. var link_sub = link_data_var[1];
  890. if(
  891. window.location.search === '' &&
  892. window.location.pathname.match(/^\/w\//)
  893. ) {
  894. window.location.href = '/w/' + do_url_change(link_main) + '?from=' + do_url_change(name_doc) + link_sub;
  895. }
  896. return [
  897. data.replace(redirect_re, '/w/' + do_url_change(link_main) + '?from=' + do_url_change(name_doc) + link_sub),
  898. data_js,
  899. 1
  900. ];
  901. } else {
  902. return [data, data_js, 0];
  903. }
  904. }
  905. function do_onmark_remark_render(data) {
  906. data = data.replace(/\n##([^\n]+)/, '');
  907. return data;
  908. }
  909. // Main
  910. function do_onmark_render(test_mode = 'test', name_id = '', name_include = '', name_doc = '', doc_data = '') {
  911. if(test_mode === 'normal') {
  912. var data = '\n' + document.getElementById(name_id).innerHTML.replace(/\r/g, '') + '\n';
  913. } else if(test_mode === 'manual') {
  914. var data = '\n' + doc_data.replace(/\r/g, '') + '\n';
  915. } else {
  916. var data = '\n' + (
  917. ``
  918. ).replace(/\r/g, '') + '\n';
  919. }
  920. var data_js = '';
  921. var data_backlink = [];
  922. var data_nowiki = {};
  923. var data_var = do_onmark_redirect_render(data, data_js, name_doc);
  924. data = data_var[0];
  925. data_js = data_var[1];
  926. var passing = data_var[2];
  927. if(passing === 0) {
  928. data = do_onmark_remark_render(data);
  929. var data_var = do_onmark_math_render(data, data_js, name_include);
  930. data = data_var[0];
  931. data_js = data_var[1];
  932. console.log('math');
  933. data_var = do_onmark_include_render(data, data_js, name_include, data_nowiki);
  934. data = data_var[0];
  935. data_js = data_var[1];
  936. console.log('include');
  937. data_var = do_onmark_middle_render(data, data_js, name_include, data_nowiki, name_doc);
  938. data = data_var[0];
  939. data_js = data_var[1];
  940. data_nowiki = data_var[2];
  941. console.log('middle');
  942. data_var = do_onmark_nowiki_before_render(data, data_js, name_include, data_nowiki);
  943. data = data_var[0];
  944. data_js = data_var[1];
  945. data_nowiki = data_var[2];
  946. console.log('nowiki');
  947. data = do_onmark_text_render(data);
  948. console.log('text');
  949. data = do_onmark_heading_render(data, name_doc, name_include);
  950. console.log('heading');
  951. data = do_onmark_table_render(data);
  952. console.log('table');
  953. data_var = do_onmark_link_render(data, data_js, name_doc, name_include, data_nowiki);
  954. data = data_var[0];
  955. data_js = data_var[1];
  956. console.log('link');
  957. data_var = do_onmark_macro_render(data, data_js);
  958. data = data_var[0];
  959. data_js = data_var[1];
  960. console.log('macro');
  961. data = do_onmark_list_render(data);
  962. console.log('list');
  963. data = do_onmark_hr_render(data);
  964. console.log('hr');
  965. data = do_onmark_footnote_render(data, name_include);
  966. console.log('footnote');
  967. data = do_onmark_last_render(data, name_include);
  968. console.log('all')
  969. }
  970. data_js += '' +
  971. 'get_link_state("' + name_include + '");\n' +
  972. 'get_file_state("' + name_include + '");\n' +
  973. ''
  974. data_js += 'render_html("' + name_include + 'nowiki_html");\n'
  975. if(test_mode === 'normal') {
  976. document.getElementById(name_id).innerHTML = data + '<script>' + data_js + '</script>';
  977. eval(data_js);
  978. } else if(test_mode === 'manual') {
  979. return [data, data_js];
  980. } else {
  981. console.log([data, data_js]);
  982. }
  983. }