render_onmark.js 45 KB

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