render_namumark.js 33 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876
  1. function render_namumark(target) {
  2. function get_today() {
  3. var today_data = new Date();
  4. return '' +
  5. String(today_data.getFullYear()) + '-' +
  6. String(today_data.getMonth() + 1) + '-' +
  7. String(today_data.getDate()) + ' ' +
  8. (today_data.getHours() < 10 ? '0' + String(today_data.getHours()) : String(today_data.getHours())) + ':' +
  9. (today_data.getMinutes() < 10 ? '0' + String(today_data.getMinutes()) : String(today_data.getMinutes())) + ':' +
  10. (today_data.getSeconds() < 10 ? '0' + String(today_data.getSeconds()) : String(today_data.getSeconds())) +
  11. '';
  12. }
  13. function get_link_state(link_data) {
  14. var xhr = new XMLHttpRequest();
  15. xhr.open("GET", "/api/w/" + encodeURIComponent(link_data[0]) + "?exist=1", true);
  16. xhr.send(null);
  17. xhr.onreadystatechange = function() {
  18. var i = 0;
  19. while(1) {
  20. if(document.getElementsByClassName(link_data[1])[i]) {
  21. if(this.readyState === 4 && this.status === 200) {
  22. if(JSON.parse(this.responseText)['exist'] !== '1') {
  23. document.getElementsByClassName(link_data[1])[i].id = "not_thing";
  24. } else {
  25. document.getElementsByClassName(link_data[1])[i].id = "";
  26. }
  27. } else {
  28. document.getElementsByClassName(link_data[1])[i].id = "not_thing";
  29. }
  30. i += 1;
  31. } else {
  32. break;
  33. }
  34. }
  35. }
  36. }
  37. function get_file_state(file_data) {
  38. var file_part = file_data[0].match(/^([^.]+)\.(.+)$/);
  39. if(file_part) {
  40. var file_name = file_part[1];
  41. var file_type = '.' + file_part[2];
  42. } else {
  43. var file_name = file_data;
  44. var file_type = '';
  45. }
  46. var xhr = new XMLHttpRequest();
  47. xhr.open("GET", "/api/sha224/" + encodeURIComponent(file_name), true);
  48. xhr.send(null);
  49. xhr.onreadystatechange = function() {
  50. if(this.readyState === 4 && this.status === 200) {
  51. var xhr = new XMLHttpRequest();
  52. xhr.open("GET", "/api/w/file:" + encodeURIComponent(file_data[0]) + "?exist=1", true);
  53. xhr.send(null);
  54. var img_src = JSON.parse(this.responseText)['data'];
  55. xhr.onreadystatechange = function() {
  56. if(this.readyState === 4 && this.status === 200) {
  57. if(JSON.parse(this.responseText)['exist'] !== '1') {
  58. document.getElementById(file_data[1]).innerHTML = '' +
  59. '<a href="/upload?name=' + encodeURIComponent(file_data[0]) + '" id="not_thing">' + file_data[0] + '</a>' +
  60. '';
  61. } else {
  62. document.getElementById(file_data[1]).innerHTML = '' +
  63. '<img src="/image/' + img_src + file_type + '">' +
  64. '';
  65. }
  66. } else {
  67. document.getElementById(file_data[1]).innerHTML = '' +
  68. '<a href="/upload?name=' + encodeURIComponent(file_data[0]) + '" id="not_thing">' + file_data[0] + '</a>' +
  69. '';
  70. }
  71. }
  72. }
  73. }
  74. }
  75. function divi_link(link_data) {
  76. var link_part = link_data.match(/^([^|]+)\|(.+)$/);
  77. if(link_part) {
  78. return [link_part[2], link_part[1]]
  79. } else {
  80. return [link_data, link_data]
  81. }
  82. }
  83. function table_analysis(main_data, cel_data, start_cel, num = 0) {
  84. var table_class = 'class="'
  85. var div_style = 'style="'
  86. var table_style = 'style="'
  87. var cel_style = 'style="'
  88. var row_style = 'style="'
  89. var row = ''
  90. var cel = ''
  91. var table_state_get = main_data.match(/&lt;table ?width=((?:(?!&gt;).)*)&gt;/);
  92. if(table_state_get) {
  93. if(main_data.match('^[0-9]+$', table_state_get[1])) {
  94. div_style += 'width: ' + table_state_get[1] + 'px;';
  95. } else {
  96. div_style += 'width: ' + table_state_get[1] + ';';
  97. }
  98. table_style += 'width: 100%;';
  99. }
  100. table_state_get = main_data.match(/&lt;table ?height=((?:(?!&gt;).)*)&gt;/);
  101. if(table_state_get) {
  102. if(main_data.match(/^[0-9]+$/, table_state_get[1])) {
  103. table_style += 'height: ' + table_state_get[1] + 'px;';
  104. } else {
  105. table_style += 'height: ' + table_state_get[1] + ';';
  106. }
  107. }
  108. table_state_get = main_data.match(/&lt;table ?align=((?:(?!&gt;).)*)&gt;/);
  109. if(table_state_get) {
  110. if(table_state_get[1] == 'right') {
  111. div_style += 'float: right;';
  112. } else if(table_state_get[1] == 'center') {
  113. table_style += 'margin: auto;';
  114. }
  115. }
  116. table_state_get = main_data.match(/&lt;table ?textalign=((?:(?!&gt;).)*)&gt;/);
  117. if(table_state_get) {
  118. num = 1
  119. if(table_state_get[1] == 'right') {
  120. table_style += 'text-align: right;';
  121. } else if(table_state_get[1] == 'center') {
  122. table_style += 'text-align: center;';
  123. }
  124. }
  125. table_state_get = main_data.match(/&lt;row ?textalign=((?:(?!&gt;).)*)&gt;/);
  126. if(table_state_get) {
  127. if(table_state_get[1] == 'right') {
  128. row_style += 'text-align: right;';
  129. } else if(table_state_get[1] == 'center') {
  130. row_style += 'text-align: center;';
  131. } else {
  132. row_style += 'text-align: left;';
  133. }
  134. }
  135. table_state_get = main_data.match(/&lt;-((?:(?!&gt;).)*)&gt;/);
  136. if(table_state_get) {
  137. cel = 'colspan="' + table_state_get[1] + '"';
  138. } else {
  139. cel = 'colspan="' + String(Math.round(start_cel.length / 2)) + '"';
  140. }
  141. table_state_get = main_data.match(/&lt;\|((?:(?!&gt;).)*)&gt;/);
  142. if(table_state_get) {
  143. row = 'rowspan="' + table_state_get[1] + '"';
  144. }
  145. table_state_get = main_data.match(/&lt;rowbgcolor=(#(?:[0-9a-f-A-F]{3}){1,2}|\w+)(?:,(#(?:[0-9a-f-A-F]{3}){1,2}|\w+))?&gt;/);
  146. if(table_state_get) {
  147. row_style += 'background: ' + table_state_get[1] + ';';
  148. }
  149. table_state_get = main_data.match(/&lt;rowcolor=(#(?:[0-9a-f-A-F]{3}){1,2}|\w+)(?:,(#(?:[0-9a-f-A-F]{3}){1,2}|\w+))?&gt;/);
  150. if(table_state_get) {
  151. row_style += 'color: ' + table_state_get[1] + ';';
  152. }
  153. table_state_get = main_data.match(/&lt;table ?bordercolor=(#(?:[0-9a-f-A-F]{3}){1,2}|\w+)(?:,(#(?:[0-9a-f-A-F]{3}){1,2}|\w+))?&gt;/);
  154. if(table_state_get) {
  155. table_style += 'border: ' + table_state_get[1] + ' 2px solid;';
  156. }
  157. table_state_get = main_data.match(/&lt;table ?bgcolor=(#(?:[0-9a-f-A-F]{3}){1,2}|\w+)(?:,(#(?:[0-9a-f-A-F]{3}){1,2}|\w+))?&gt;/);
  158. if(table_state_get) {
  159. table_style += 'background: ' + table_state_get[1] + ';';
  160. }
  161. table_state_get = main_data.match(/&lt;table ?color=(#(?:[0-9a-f-A-F]{3}){1,2}|\w+)(?:,(#(?:[0-9a-f-A-F]{3}){1,2}|\w+))?&gt;/);
  162. if(table_state_get) {
  163. table_style += 'color: ' + table_state_get[1] + ';';
  164. }
  165. table_state_get = main_data.match(/&lt;(?:bgcolor=)?(#(?:[0-9a-f-A-F]{3}){1,2}|\w+)(?:,(#(?:[0-9a-f-A-F]{3}){1,2}|\w+))?&gt;/);
  166. if(table_state_get) {
  167. cel_style += 'background: ' + table_state_get[1] + ';';
  168. }
  169. table_state_get = main_data.match(/&lt;color=(#(?:[0-9a-f-A-F]{3}){1,2}|\w+)(?:,(#(?:[0-9a-f-A-F]{3}){1,2}|\w+))?&gt;/);
  170. if(table_state_get) {
  171. cel_style += 'color: ' + table_state_get[1] + ';';
  172. }
  173. table_state_get = main_data.match(/&lt;width=((?:(?!&gt;).)*)&gt;/);
  174. if(table_state_get) {
  175. if(table_state_get[1].match(/^[0-9]+$/)) {
  176. cel_style += 'width: ' + table_state_get[1] + 'px;';
  177. } else {
  178. cel_style += 'width: ' + table_state_get[1] + ';';
  179. }
  180. }
  181. table_state_get = main_data.match(/&lt;height=((?:(?!&gt;).)*)&gt;/);
  182. if(table_state_get) {
  183. if(table_state_get[1].match(/^[0-9]+$/)) {
  184. cel_style += 'height: ' + table_state_get[1] + 'px;';
  185. } else {
  186. cel_style += 'height: ' + table_state_get[1] + ';';
  187. }
  188. }
  189. var text_right = main_data.match(/&lt;\)&gt;/);
  190. var text_center = main_data.match(/&lt;:&gt;/);
  191. var text_left = main_data.match(/&lt;\(&gt;/);
  192. if(text_right) {
  193. cel_style += 'text-align: right;';
  194. } else if(text_center) {
  195. cel_style += 'text-align: center;';
  196. } else if(text_left) {
  197. cel_style += 'text-align: left;';
  198. } else if(num == 0) {
  199. if(cel_data.match(/^ /) && cel_data.match(/ $/)) {
  200. cel_style += 'text-align: center;';
  201. } else if(cel_data.match(/^ /)) {
  202. cel_style += 'text-align: right;';
  203. } else if(cel_data.match(/ $/)) {
  204. cel_style += 'text-align: left;';
  205. }
  206. }
  207. table_state_get = main_data.match(/&lt;table ?class=((?:(?!&gt;).)+)&gt;/);
  208. if(table_state_get) {
  209. table_class += table_state_get[1];
  210. }
  211. div_style += '"';
  212. table_style += '"';
  213. cel_style += '"';
  214. row_style += '"';
  215. table_class += '"';
  216. return [table_style, row_style, cel_style, row, cel, table_class, num, div_style]
  217. }
  218. function table_render(data) {
  219. var table_num = 0;
  220. while(1) {
  221. var table_data = data.match(/\n((?:(?:(?:(?:\|\|)+(?:(?:(?!\|\|).(?:\n)*)*))+)\|\|(?:\n)?)+)/);
  222. if(table_data) {
  223. table_data = table_data[1];
  224. var get_table_data = table_data.match(/^((?:\|\|)+)((?:&lt;(?:(?:(?!&gt;).)+)&gt;)*)\n*((?:(?!\|\|).\n*)*)/);
  225. if(get_table_data) {
  226. table_return_data = table_analysis(get_table_data[2], get_table_data[3], get_table_data[1]);
  227. table_num = table_return_data[6];
  228. table_data = table_data.replace(
  229. /^((?:\|\|)+)((?:&lt;(?:(?:(?!&gt;).)+)&gt;)*)\n*/,
  230. '\n' +
  231. '<div class="table_safe" ' + table_return_data[7] + '>' +
  232. '<table ' + table_return_data[5] + ' ' + table_return_data[0] + '>' +
  233. '<tr ' + table_return_data[1] + '>' +
  234. '<td ' + table_return_data[2] + ' ' + table_return_data[3] + ' ' + table_return_data[4] + '>'
  235. );
  236. }
  237. table_data = table_data.replace(/\|\|\n?$/, '</td></tr></table></div>');
  238. while(1) {
  239. get_table_data = table_data.match(/\|\|\n((?:\|\|)+)((?:&lt;(?:(?:(?!&gt;).)+)&gt;)*)\n*((?:(?!\|\||<\/td>).\n*)*)/);
  240. if(get_table_data) {
  241. table_return_data = table_analysis(get_table_data[2], get_table_data[3], get_table_data[1], table_num);
  242. table_data = table_data.replace(
  243. /\|\|\n((?:\|\|)+)((?:&lt;(?:(?:(?!&gt;).)+)&gt;)*)\n*/,
  244. '</td></tr><tr ' + table_return_data[1] + '><td ' + table_return_data[2] + ' ' + table_return_data[3] + ' ' + table_return_data[4] + '>'
  245. );
  246. } else {
  247. break;
  248. }
  249. }
  250. while(1) {
  251. get_table_data = table_data.match(/((?:\|\|)+)((?:&lt;(?:(?:(?!&gt;).)+)&gt;)*)\n*((?:(?:(?!\|\||<\/td>).)|\n)*\n*)/);
  252. if(get_table_data) {
  253. table_return_data = table_analysis(get_table_data[2], get_table_data[3].replace(/\n/g, ' '), get_table_data[1], table_num);
  254. table_data = table_data.replace(
  255. /((?:\|\|)+)((?:&lt;(?:(?:(?!&gt;).)+)&gt;)*)\n*/,
  256. '</td><td ' + table_return_data[2] + ' ' + table_return_data[3] + ' ' + table_return_data[4] + '>'
  257. );
  258. } else {
  259. break;
  260. }
  261. }
  262. data = data.replace(/\n((?:(?:(?:(?:\|\|)+(?:(?:(?!\|\|).(?:\n)*)*))+)\|\|(?:\n)?)+)/, table_data);
  263. } else {
  264. break;
  265. }
  266. }
  267. return data;
  268. }
  269. var data = '\n' + document.getElementById(target).innerHTML + '\n';
  270. var title = window.location.pathname.replace(/^\/w\//, '');
  271. var math_list = [];
  272. var math_num = 0;
  273. data = data.replace(/\[math\(((?:(?!\)]).)+)\)]/ig, function(all, in_data) {
  274. var math_data = in_data.replace(/&amp;/g, "&").replace(/&lt;/g, "<").replace(/&gt;/g, ">").replace(/&quot;/g, "\"").replace(/&#039;/g, "'");
  275. math_num += 1;
  276. math_list.push(['math_' + String(math_num), math_data]);
  277. return '<span id="math_' + String(math_num) + '"></span>';
  278. });
  279. var i = 0;
  280. var mid_num = 0;
  281. var mid_stack = 0;
  282. var mid_list = [];
  283. var html_num = 0;
  284. var fol_num = 0;
  285. var mid_regex = /(?:{{{(?:((?:(?! |{{{|}}}|&lt;).)*) ?)|(}}}))/;
  286. var all_mid_data = data.match(new RegExp(mid_regex.source, 'g'));
  287. // 이거 손 봐야함
  288. while(1) {
  289. if(all_mid_data[i]) {
  290. i += 1;
  291. if(all_mid_data[i][0] === '}}}') {
  292. if(mid_stack > 0) {
  293. mid_stack -= 1;
  294. }
  295. if(mid_stack > 0) {
  296. data.replace(mid_regex, all_mid_data[i][0]);
  297. } else {
  298. if(mid_num > 0) {
  299. mid_num -= 1;
  300. }
  301. if(!mid_list[mid_num]) {
  302. var return_data = '';
  303. } else if(mid_list[mid_num] === 'pre') {
  304. var return_data = '</code></pre>';
  305. } else if(mid_list[mid_num] === 'div_2') {
  306. var return_data = '</div_1></div>';
  307. } else {
  308. var return_data = '</' + mid_list[mid_num] + '>';
  309. }
  310. if(return_data !== '') {
  311. mid_list.splice(mid_num, 1);
  312. data.replace(mid_regex, return_data);
  313. } else {
  314. data.replace(mid_regex, all_mid_data[i][0]);
  315. }
  316. }
  317. } else {
  318. if(mid_stack > 0) {
  319. mid_stack += 1;
  320. data.replace(mid_regex, all_mid_data[i][0]);
  321. } else {
  322. mid_num += 1;
  323. if(in_data.match(/^(#|@|\+|\-)/) && !in_data.match(/^(#|@|\+|\-){2}|(#|@|\+|\-)\\\\/)) {
  324. if(in_data.match(/^((#|@)([0-9a-f-A-F]{3}){1,2})/)) {
  325. mid_list.push('span');
  326. if(in_data.match(/^#/)) {
  327. data.replace(mid_regex, '<span style="color: ' + in_data + ';">');
  328. } else {
  329. data.replace(mid_regex, '<span style="background: ' + in_data + ';">');
  330. }
  331. } else if(in_data.match(/^((#|@)(\w+))/)) {
  332. mid_list.push('span');
  333. if(in_data.match(/^#/)) {
  334. data.replace(mid_regex, '<span style="color: ' + in_data.replace(/^#/, '') + ';">');
  335. } else {
  336. data.replace(mid_regex, '<span style="background: ' + in_data.replace(/^@/, '') + ';">');
  337. }
  338. } else if(in_data.match(/^(\+|-)([1-5])/)) {
  339. mid_list.push('span');
  340. var font_size_data = in_data.match(/^(\+|-)([1-5])/);
  341. if(font_size_data[1] == '+') {
  342. font_size_data = String(Number(font_size_data[2]) * 20 + 100);
  343. } else {
  344. font_size_data = String(100 - Number(font_size_data[2]) * 10);
  345. }
  346. data.replace(mid_regex, '<span style="font-size: ' + font_size_data + '%;">');
  347. } else if(in_data.match(/#!wiki/i)) {
  348. mid_list.push('div_1');
  349. data.replace(mid_regex, '<div id="wiki_div_before">');
  350. } else if(in_data.match(/#!syntax/i)) {
  351. mid_list.push('pre');
  352. mid_stack += 1;
  353. data.replace(mid_regex, '<pre><code id="syntax_before">');
  354. } else if(in_data.match(/#!folding/i)) {
  355. mid_list.push('div_2');
  356. ata.replace(mid_regex, '' +
  357. '<div style="display: inline-block;">' +
  358. '<a href="javascript:void(0);" onclick="do_open_folding(\'folding_' + String(fol_num) + '\', this);">' +
  359. '[+]' +
  360. '</a>' +
  361. '</div>' +
  362. '<div id="folding_' + String(fol_num) + '" style="display: none;">' +
  363. '<div id="wiki_div" style="">' +
  364. '');
  365. } else if(in_data.match(/#!html/i)) {
  366. mid_list.push('span');
  367. html_num += 1;
  368. data.replace(mid_regex, '<span id="html_render_contect_' + String(html_num) + '">');
  369. } else {
  370. mid_list.push('code');
  371. mid_stack += 1;
  372. data.replace(mid_regex, '<code>' + in_data);
  373. }
  374. } else {
  375. mid_list.push('code');
  376. mid_stack += 1;
  377. data.replace(mid_regex, '<code>' + in_data);
  378. }
  379. }
  380. }
  381. } else {
  382. break;
  383. }
  384. }
  385. data = data.replace(/<\/div> *\n/ig, '</div>');
  386. var nowiki_num = 0;
  387. var nowiki_list = {};
  388. data = data.replace(/<code>(\n*((?:(?!<\/code>).)+\n*)+)<\/code>/g, function(all, in_data) {
  389. nowiki_num += 1;
  390. nowiki_list['nowiki_' + String(nowiki_num)] = in_data;
  391. return '<span id="nowiki_' + String(nowiki_num) + '"></span>';
  392. });
  393. data = data.replace(/\r\n/g, '\n');
  394. data = data.replace(/&amp;/g, '&');
  395. data = data.replace(/\n(?: +)\|\|/g, '\n||');
  396. data = data.replace(/\|\|(?: +)\n/g, '||\n');
  397. data = data.replace(/\n##(?:(?:(?!\n).)+)/g, '');
  398. data = data.replace(/<div id="wiki_div" style="">\n/g, '<div id="wiki_div" style="">');
  399. data = data.replace(/<div id="wiki_div" style=""> +/g, '<div id="wiki_div" style="">');
  400. console.log(data);
  401. console.log('----')
  402. while(1) {
  403. wiki_table_data = data.match(/<div id="wiki_div" ((?:(?!>).)+)>((?:(?!<div id="wiki_div"|<\/div_1>).\n*)+)<\/div_1>/i);
  404. if(wiki_table_data) {
  405. if(wiki_table_data[2].match(/\|\|/)) {
  406. console.log('1')
  407. console.log(wiki_table_data[2]);
  408. var end_table_render = table_render('\n' + wiki_table_data[2] + '\n').replace(/^\n/, '').replace(/\n$/, '');
  409. } else {
  410. var end_table_render = wiki_table_data[2];
  411. }
  412. data = data.replace(
  413. /<div id="wiki_div" ((?:(?!>).)+)>((?:(?!<div id="wiki_div"|<\/div_1>).\n*)+)<\/div_1>/i,
  414. '<div ' + wiki_table_data[1] + '>' + end_table_render + '</div>'
  415. );
  416. } else {
  417. break;
  418. }
  419. }
  420. data = data.replace(/<\/td>/g, '</td_1>');
  421. data = data.replace(/~~((?:(?!~~).)+)~~/g, '<s>$1</s>');
  422. data = data.replace(/--((?:(?!--).)+)--/g, '<s>$1</s>');
  423. data = data.replace(/__((?:(?!__).)+)__/g, '<u>$1</u>');
  424. data = data.replace(/'''((?:(?!''').)+)'''/g, '<b>$1</b>');
  425. data = data.replace(/''((?:(?!'').)+)''/g, '<i>$1</i>');
  426. data = data.replace(/\^\^((?:(?!\^\^).)+)\^\^/g, '<sup>$1</sup>');
  427. data = data.replace(/,,((?:(?!,,).)+),,/g, '<sub>$1</sub>');
  428. var toc_array = [0, 0, 0, 0, 0, 0];
  429. var before_data = 0;
  430. var edit_number = 0;
  431. var toc_data = '<div id="toc"><span id="toc_title">TOC</span>\n\n'
  432. data = data.replace(/\n(={1,6}) ?([^\n]+) (?:={1,6})/g, function(all, num, in_data) {
  433. num = num.length;
  434. edit_number += 1;
  435. if(before_data > num) {
  436. var i = num;
  437. while(1) {
  438. if(i == 6) {
  439. break;
  440. }
  441. toc_array[i] = 0;
  442. i += 1;
  443. }
  444. }
  445. before_data = num;
  446. toc_array[num - 1] += 1;
  447. num = String(num);
  448. var toc_num = (toc_array.join('.') + '.').replace(/0\./g, '');
  449. if(!toc_num.match(/\./)) {
  450. toc_num += '0.';
  451. }
  452. toc_data += '' +
  453. '<span style="margin-left: ' + String(10 * (toc_num.length / 2) - 10) + 'px;">' +
  454. '<a href="#s-' + toc_num.replace(/\.$/, '') + '">' + toc_num + '</a> ' + in_data +
  455. '</span>' +
  456. '\n' +
  457. '';
  458. return '' +
  459. '\n' +
  460. '<h' + num + ' id="s-' + toc_num.replace(/\.$/, '') + '">' +
  461. '<a href="#toc">' + toc_num + '</a> ' + in_data +
  462. '<span style="font-size: 12px">' +
  463. '<a href="/edit/' + title + '?section=' + String(edit_number) + '">(Edit)</a>' +
  464. '</span>' +
  465. '</h' + num + '>' +
  466. '';
  467. });
  468. toc_data += '</div>';
  469. data = data.replace(/<\/h([0-9])>\n/g, '</h$1>');
  470. while(1) {
  471. if(data.match(/(\n(?:&gt; ?(?:[^\n]+)?\n?)+)/)) {
  472. data = data.replace(/(\n(?:&gt; ?(?:[^\n]+)?\n?)+)/, function(all, in_data) {
  473. var new_in_data = in_data;
  474. new_in_data = new_in_data.replace(/^\n&gt; ?/, '');
  475. new_in_data = new_in_data.replace(/\n&gt; ?/g, '\n');
  476. new_in_data = new_in_data.replace(/\n$/, '');
  477. return '\n<blockquote>' + new_in_data + '</blockquote>\n';
  478. });
  479. } else {
  480. break;
  481. }
  482. }
  483. while(1) {
  484. if(data.match(/\n-{4,9}\n/)) {
  485. data = data.replace(/\n-{4,9}\n/, function() {
  486. return '\n<hr>\n';
  487. });
  488. } else {
  489. break;
  490. }
  491. }
  492. data = data.replace(/(\n +\* ?(?:(?:(?!\|\|).)+))\|\|/g, '$1\n ||');
  493. data = data.replace(/\n( {1,})\* ([^\n]+)/g, function(all, margin_data, in_data) {
  494. return '<li style="margin-left: ' + String(margin_data.length * 20) + 'px;">' + in_data + '</li>'
  495. });
  496. data = data.replace(/\|\|<li/g, '||\n<li');
  497. data = data.replace(/\n( {1,})/g, function(all, margin_data) {
  498. return '\n<span style="margin-left: ' + String(margin_data.length * 10) + 'px"></span>'
  499. });
  500. console.log(data);
  501. data = table_render(data);
  502. var link_list = [];
  503. var file_list = [];
  504. var link_num = 0;
  505. var file_num = 0;
  506. var category = ''
  507. while(1) {
  508. if(data.match(/\[\[((?:(?!\[\[|]]).)+)]]/)) {
  509. data = data.replace(/\[\[((?:(?!\[\[|]]).)+)]]/, function(all, in_data) {
  510. if(in_data.match(/^(?:category|분류):/i)) {
  511. var back_data = in_data.replace(/^(?:category|분류):/i, '');
  512. var front_data = back_data;
  513. back_data = 'category:' + back_data.replace(/#blur$/, '');
  514. if(front_data.match(/#blur$/)) {
  515. front_data = '#blur';
  516. }
  517. link_list.push([back_data, 'link_' + String(link_num)]);
  518. link_num += 1;
  519. if(category === '') {
  520. category += '<div id="cate_all"><hr><div id="cate">Category : '
  521. }
  522. category += '<a class="link_' + String(link_num - 1) + '" href="' + encodeURIComponent(back_data) + '">' + front_data + '</a> | ';
  523. return '';
  524. } else if(in_data.match(/^(?:file|파일):/i)) {
  525. file_list.push([in_data.replace(/^(?:file|파일):/i, ''), 'file_' + String(file_num)]);
  526. file_num += 1;
  527. return '<span id="file_' + String(file_num - 1) + '"></span>';
  528. } else if(in_data.match(/^http(?:s)?:\/\//i)) {
  529. var link_part = divi_link(in_data);
  530. var front_data = link_part[0];
  531. var back_data = link_part[1];
  532. return '<a id="out_link" href="' + back_data + '">' + front_data + '</a>';
  533. } else {
  534. var link_part = divi_link(in_data);
  535. var front_data = link_part[0];
  536. var back_data = link_part[1];
  537. link_list.push([back_data, 'link_' + String(link_num)]);
  538. link_num += 1;
  539. return '<a class="link_' + String(link_num - 1) + '" href="/w/' + encodeURIComponent(back_data) + '">' + front_data + '</a>';
  540. }
  541. });
  542. } else {
  543. break;
  544. }
  545. }
  546. if(category !== '') {
  547. category = category.replace(/ \| $/, '') + '</div></div>'
  548. }
  549. data = data.replace(/\[([^(\]]+)\(((?:(?!\)]).)+)\)]/g, function(all, name, in_data) {
  550. if(name.match(/^youtube|kakaotv|nicovideo$/i)) {
  551. var video_code = in_data.match(/^([^,]+)/);
  552. if(video_code) {
  553. video_code = video_code[1];
  554. } else {
  555. video_code = 'test';
  556. }
  557. if(name === 'youtube') {
  558. var video_src = 'https://www.youtube.com/embed/' + video_code
  559. } else if(name === 'kakaotv') {
  560. var video_src = 'https://tv.kakao.com/embed/player/cliplink/' + video_code +'?service=kakao_tv'
  561. } else {
  562. var video_src = 'https://embed.nicovideo.jp/watch/' + video_code
  563. }
  564. var width_data = in_data.match(/, *width=([^,]+)/);
  565. if(width_data) {
  566. width_data = width_data[1];
  567. } else {
  568. width_data = '560';
  569. }
  570. var height_data = in_data.match(/, *height=([^,]+)/);
  571. if(height_data) {
  572. height_data = height_data[1];
  573. } else {
  574. height_data = '315';
  575. }
  576. return '' +
  577. '<iframe ' +
  578. 'width="' + width_data + '" ' +
  579. 'height="' + height_data + '" ' +
  580. 'src="' + video_src + '" ' +
  581. 'allowfullscreen>' +
  582. '</iframe>' +
  583. '';
  584. } else if(name.match(/^ruby$/i)) {
  585. var main_text = in_data.match(/^([^,]+)/);
  586. if(main_text) {
  587. main_text = main_text[1];
  588. } else {
  589. main_text = 'test';
  590. }
  591. var ruby_text = in_data.match(/, *ruby=([^,]+)/);
  592. if(ruby_text) {
  593. ruby_text = ruby_text[1];
  594. } else {
  595. ruby_text = 'test';
  596. }
  597. var color_text = in_data.match(/, *color=([^,]+)/);
  598. if(color_text) {
  599. color_text = 'color:' + color_text[1];
  600. } else {
  601. color_text = '';
  602. }
  603. return '' +
  604. '<ruby>' +
  605. main_text +
  606. '<rp>(</rp>' +
  607. '<rt>' +
  608. '<span style="' + color_text + '">' + ruby_text + '</span>' +
  609. '</rt>' +
  610. '<rp>)</rp>' +
  611. '</ruby>' +
  612. '';
  613. } else if(name.match(/^anchor$/i)) {
  614. return '<span id="' + in_data + '"></span>';
  615. } else {
  616. return all;
  617. }
  618. });
  619. data = data.replace(/\[([^\]]+)\]/g, function(all, name) {
  620. if(name.match(/^br$/i)) {
  621. return '\n'
  622. } else if(name.match(/^목차|tableofcontents$/i)) {
  623. return toc_data;
  624. } else if(name.match(/^date|datetime$/i)) {
  625. return get_today();
  626. } else {
  627. return all;
  628. }
  629. });
  630. var ref_num = 0;
  631. var ref_data = '<hr><ul id="footnote_data">';
  632. var name_ref_data = {};
  633. while(1) {
  634. if(data.match(/(?:\[\*([^ \]]*)(?: ((?:(?!\[\*|\]).)+))?\]|\[(?:각주|footnote)])/)) {
  635. data = data.replace(/(?:\[\*([^ \]]*)(?: ((?:(?!\[\*|\]).)+))?\]|\[(?:각주|footnote)])/, function(all, name_data, in_data) {
  636. if(all.match(/^\[(?:각주|footnote)]$/i)) {
  637. var new_ref_data = ref_data;
  638. ref_data = '<hr><ul id="footnote_data">';
  639. return new_ref_data + '</ul>';
  640. } else {
  641. ref_num += 1;
  642. if(name_data) {
  643. if(in_data) {
  644. name_ref_data[name_data] = in_data;
  645. ref_data += '' +
  646. '<li>' +
  647. '<a id="fn-' + name_data + '" href="#rfn-' + String(ref_num) + '">(' + name_data + ')</a> ' + in_data + ''
  648. '</li>' +
  649. ''
  650. } else {
  651. ref_data += '' +
  652. '<li>' +
  653. '<a href="#rfn-' + String(ref_num) + '">(' + name_data + ')</a>' +
  654. '</li>' +
  655. ''
  656. }
  657. } else {
  658. ref_data += '' +
  659. '<li>' +
  660. '<a id="fn-' + String(ref_num) + '" href="#rfn-' + String(ref_num) + '">(' + String(ref_num) + ')</a> ' + in_data + ''
  661. '</li>' +
  662. ''
  663. }
  664. if(name_data) {
  665. return '' +
  666. '<sup>' +
  667. '<a href="#fn-' + name_data + '" id="rfn-' + String(ref_num) + '" title="' + name_ref_data[name_data].replace(/<([^>]*)>/g, '') + '">' +
  668. '(' + name_data + ')' +
  669. '</a>' +
  670. '</sup>' +
  671. '';
  672. } else {
  673. return '' +
  674. '<sup>' +
  675. '<a href="#fn-' + String(ref_num) + '" id="rfn-' + String(ref_num) + '" title="' + in_data.replace(/<([^>]*)>/g, '') + '">' +
  676. '(' + String(ref_num) + ')' +
  677. '</a>' +
  678. '</sup>' +
  679. '';
  680. }
  681. }
  682. });
  683. } else {
  684. break;
  685. }
  686. }
  687. if(ref_data !== '<hr><ul id="footnote_data">') {
  688. data += ref_data + '</ul>';
  689. }
  690. var i = 1;
  691. while(1) {
  692. if(nowiki_list['nowiki_' + String(i)]) {
  693. data = data.replace('<span id="nowiki_' + String(i) + '"></span>', '<code>' + nowiki_list['nowiki_' + String(i)] + '</code>');
  694. i += 1;
  695. } else {
  696. break;
  697. }
  698. }
  699. data = data.replace(/<\/td_1>/g, '</td>');
  700. data = data.replace(/^(\n| )+/g, '');
  701. data = data.replace(/(\n| )+$/g, '');
  702. data = data.replace(/\n/g, '<br>');
  703. data = data.replace(/&amp;/g, '&');
  704. data += category;
  705. document.getElementById(target).innerHTML = data;
  706. i = 0;
  707. while(1) {
  708. if(math_list[i]) {
  709. try {
  710. katex.render(math_list[i][1], document.getElementById(math_list[i][0]));
  711. } catch {
  712. try {
  713. document.getElementById(math_list[i][0]).innerHTML = '<span style="color: red;">' + math_list[i][1] + '</span>';
  714. } catch {}
  715. }
  716. i += 1;
  717. } else {
  718. break;
  719. }
  720. }
  721. i = 0;
  722. while(1) {
  723. if(link_list[i]) {
  724. get_link_state(link_list[i]);
  725. i += 1;
  726. } else {
  727. break;
  728. }
  729. }
  730. i = 0;
  731. while(1) {
  732. if(file_list[i]) {
  733. get_file_state(file_list[i]);
  734. i += 1;
  735. } else {
  736. break;
  737. }
  738. }
  739. render_html("html_render_contect");
  740. // v0.0.6
  741. // 어느 정도 괜찮은 수준까진 옴
  742. }