render_onmark.js 33 KB

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