render_namumark.js 35 KB

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