| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531 |
- function render_namumark(target) {
- function get_today() {
- var today_data = new Date();
- return '' +
- String(today_data.getFullYear()) + '-' +
- String(today_data.getMonth() + 1) + '-' +
- String(today_data.getDate()) + ' ' +
- (today_data.getHours() < 10 ? '0' + String(today_data.getHours()) : String(today_data.getHours())) + ':' +
- (today_data.getMinutes() < 10 ? '0' + String(today_data.getMinutes()) : String(today_data.getMinutes())) + ':' +
- (today_data.getSeconds() < 10 ? '0' + String(today_data.getSeconds()) : String(today_data.getSeconds())) +
- '';
- }
- function get_link_state(link_data) {
- var xhr = new XMLHttpRequest();
- xhr.open("GET", "/api/w/" + encodeURIComponent(link_data[0]) + "?exist=1", true);
- xhr.send(null);
-
- xhr.onreadystatechange = function() {
- if(this.readyState === 4 && this.status === 200) {
- if(JSON.parse(this.responseText)['exist'] !== '1') {
- document.getElementsByClassName(link_data[1])[0].id = "not_thing";
- } else {
- document.getElementsByClassName(link_data[1])[0].id = "";
- }
- } else {
- document.getElementsByClassName(link_data[1])[0].id = "not_thing";
- }
- }
- }
- function get_file_state(file_data) {
- var file_part = file_data[0].match(/^([^.]+)\.(.+)$/);
- if(file_part) {
- var file_name = file_part[1];
- var file_type = '.' + file_part[2];
- } else {
- var file_name = file_data;
- var file_type = '';
- }
- var xhr = new XMLHttpRequest();
- xhr.open("GET", "/api/sha224/" + encodeURIComponent(file_name), true);
- xhr.send(null);
-
- xhr.onreadystatechange = function() {
- if(this.readyState === 4 && this.status === 200) {
- var xhr = new XMLHttpRequest();
- xhr.open("GET", "/api/w/file:" + encodeURIComponent(file_data[0]) + "?exist=1", true);
- xhr.send(null);
- var img_src = JSON.parse(this.responseText)['data'];
-
- xhr.onreadystatechange = function() {
- if(this.readyState === 4 && this.status === 200) {
- if(JSON.parse(this.responseText)['exist'] !== '1') {
- document.getElementById(file_data[1]).innerHTML = '' +
- '<a href="/upload?name=' + encodeURIComponent(file_data[0]) + '" id="not_thing">' + file_data[0] + '</a>' +
- '';
- } else {
- document.getElementById(file_data[1]).innerHTML = '' +
- '<img src="/image/' + img_src + file_type + '">' +
- '';
- }
- } else {
- console.log(file_data[1]);
- document.getElementById(file_data[1]).innerHTML = '' +
- '<a href="/upload?name=' + encodeURIComponent(file_data[0]) + '" id="not_thing">' + file_data[0] + '</a>' +
- '';
- }
- }
- }
- }
- }
- function divi_link(link_data) {
- var link_part = link_data.match(/^([^|]+)\|(.+)$/);
- if(link_part) {
- return [link_part[2], link_part[1]]
- } else {
- return [link_data, link_data]
- }
- }
- var data = '\n' + document.getElementById(target).innerHTML + '\n';
- var mid_num = 0;
- var mid_stack = 0;
- var mid_list = [];
- var html_number = 0;
- data = data.replace(/(?:{{{(?:((?:(?! |{{{|}}}|<).)*) ?)|(}}}))/g, function(all, in_data) {
- if(all === '}}}') {
- if(mid_stack > 0) {
- mid_stack -= 1;
- }
- if(mid_stack > 0) {
- return all;
- } else {
- if(mid_num > 0) {
- mid_num -= 1;
- }
- if(!mid_list[mid_num]) {
- var return_data = '';
- } else if(mid_list[mid_num] === 'pre') {
- var return_data = '</code></pre>';
- } else {
- var return_data = '</' + mid_list[mid_num] + '>';
- }
- if(return_data !== '') {
- mid_list.splice(mid_num, 1);
- return return_data;
- } else {
- return all;
- }
- }
- } else {
- if(mid_stack > 0) {
- mid_stack += 1;
- return all;
- } else {
- mid_num += 1;
- if(in_data.match(/^(#|@|\+|\-)/) && !in_data.match(/^(#|@|\+|\-){2}|(#|@|\+|\-)\\\\/)) {
- if(in_data.match(/^((#|@)([0-9a-f-A-F]{3}){1,2})/)) {
- mid_list.push('span');
- if(in_data.match(/^#/)) {
- return '<span style="color: ' + in_data + ';">';
- } else {
- return '<span style="background: ' + in_data + ';">';
- }
- } else if(in_data.match(/^((#|@)(\w+))/)) {
- mid_list.push('span');
- if(in_data.match(/^#/)) {
- return '<span style="color: ' + in_data.replace(/^#/, '') + ';">';
- } else {
- return '<span style="background: ' + in_data.replace(/^@/, '') + ';">';
- }
- } else if(in_data.match(/^(\+|-)([1-5])/)) {
- mid_list.push('span');
- var font_size_data = in_data.match(/^(\+|-)([1-5])/);
- if(font_size_data[1] == '+') {
- font_size_data = String(Number(font_size_data[2]) * 20 + 100);
- } else {
- font_size_data = String(100 - Number(font_size_data[2]) * 10);
- }
- return '<span style="font-size: ' + font_size_data + '%;">'
- } else if(in_data.match(/#!wiki/i)) {
- mid_list.push('div');
- if(data.match(/{{{#!wiki style=((?:(?!\n).)+) *\n/i)) {
- return '<div id="wiki_div_before">';
- } else {
- return '<div id="wiki_div">'
- }
- } else if(in_data.match(/#!syntax/i)) {
- mid_list.push('pre');
- mid_stack += 1;
-
- return '<pre><code id="syntax_before">';
- } else if(in_data.match(/#!folding/i)) {
- mid_list.push('div');
-
- return '<div id="folding_before">';
- } else if(in_data.match(/#!html/i)) {
- mid_list.push('span');
- html_number += 1;
- return '<span id="html_render_contect_' + String(html_number) + '">';
- } else {
- mid_list.push('code');
- mid_stack += 1;
-
- return '<code>' + in_data;
- }
- } else {
- mid_list.push('code');
- mid_stack += 1;
- return '<code>' + in_data;
- }
- }
- }
- });
- console.log(mid_stack);
- console.log(mid_num);
- console.log(mid_list);
- data = data.replace(/<\/div> *\n/ig, '</div>');
- data = data.replace(/<div id="folding_before">((?:(?!\n).)+) *\n/ig, function(all, in_data) {
- return in_data + ' [+]<div id="folding">';
- });
-
- data = data.replace(/<pre><code id="syntax_before">((?:(?!\n).)+) *\n/ig, function(all, in_data) {
- return '<pre><code>';
- });
- data = data.replace(/<div id="wiki_div_before">style=((?:(?!\n).)+) *\n/ig, function(all, in_data) {
- return '<div style=' + in_data.replace(/"/g, "\"").replace(/'/g, "'") + ' id="wiki_div">';
- });
- var nowiki_num = 0;
- var nowiki_list = {};
- data = data.replace(/<code>((?:(?!<\/code>).)+)<\/code>/gm, function(all, in_data) {
- nowiki_num += 1;
- nowiki_list['nowiki_' + String(nowiki_num)] = in_data;
- return '<span id="nowiki_' + String(nowiki_num) + '"></span>';
- });
- var math_list = [];
- var math_num = 0;
- data = data.replace(/\[math\(((?:(?!\)]).)+)\)]/ig, function(all, in_data) {
- var math_data = in_data.replace(/&/g, "&").replace(/</g, "<").replace(/>/g, ">").replace(/"/g, "\"").replace(/'/g, "'");
- math_num += 1;
- math_list.push(['math_' + String(math_num), math_data]);
- return '<span id="math_' + String(math_num) + '"></span>';
- });
- data = data.replace(/~~((?:(?!~~).)+)~~/g, '<s>$1</s>');
- data = data.replace(/--((?:(?!--).)+)--/g, '<s>$1</s>');
- data = data.replace(/__((?:(?!__).)+)__/g, '<u>$1</u>');
- data = data.replace(/'''((?:(?!''').)+)'''/g, '<b>$1</b>');
- data = data.replace(/''((?:(?!'').)+)''/g, '<i>$1</i>');
- data = data.replace(/\^\^((?:(?!\^\^).)+)\^\^/g, '<sup>$1</sup>');
- data = data.replace(/,,((?:(?!,,).)+),,/g, '<sub>$1</sub>');
- data = data.replace(/\n( {1,})\* ([^\n]+)/g, function(all, margin_data, in_data) {
- return '<li style="margin-left: ' + String(margin_data.length * 20) + 'px;">' + in_data + '</li>'
- });
- data = data.replace(/\n( {1,})/g, function(all, margin_data) {
- return '\n<span style="margin-left: ' + String(margin_data.length * 10) + 'px"></span>'
- });
- var link_list = [];
- var file_list = [];
- var link_num = 0;
- var file_num = 0;
- var category = '<div id="cate_all"><hr><div id="cate">Category : '
- data = data.replace(/\[\[((?:(?!]]).)+)]]/g, function(all, in_data) {
- if(in_data.match(/^(?:category|분류):/i)) {
- category += '<a href="' + encodeURIComponent(in_data) + '">' + in_data + '</a> | ';
- return '';
- } else if(in_data.match(/^(?:file|파일):/i)) {
- file_list.push([in_data.replace(/^(?:file|파일):/i, ''), 'file_' + String(file_num)]);
- file_num += 1;
-
- return '<span id="file_' + String(file_num - 1) + '"></span>';
- } else if(in_data.match(/^http(?:s)?:\/\//i)) {
- var link_part = divi_link(in_data);
-
- var front_data = link_part[0];
- var back_data = link_part[1];
- return '<a id="out_link" href="' + back_data + '">' + front_data + '</a>';
- } else {
- var link_part = divi_link(in_data);
-
- var front_data = link_part[0];
- var back_data = link_part[1];
- link_list.push([back_data, 'link_' + String(link_num)]);
- link_num += 1;
- return '<a class="link_' + String(link_num - 1) + '" href="/w/' + encodeURIComponent(back_data) + '">' + front_data + '</a>';
- }
- });
- data = data.replace(/\[([^(\]]+)\(((?:(?!\)]).)+)\)]/g, function(all, name, in_data) {
- if(name.match(/^youtube|kakaotv|nicovideo$/i)) {
- var video_code = in_data.match(/^([^,]+)/);
- if(video_code) {
- video_code = video_code[1];
- } else {
- video_code = 'test';
- }
- if(name === 'youtube') {
- var video_src = 'https://www.youtube.com/embed/' + video_code
- } else if(name === 'kakaotv') {
- var video_src = 'https://tv.kakao.com/embed/player/cliplink/' + video_code +'?service=kakao_tv'
- } else {
- var video_src = 'https://embed.nicovideo.jp/watch/' + video_code
- }
- var width_data = in_data.match(/, *width=([^,]+)/);
- if(width_data) {
- width_data = width_data[1];
- } else {
- width_data = '560';
- }
- var height_data = in_data.match(/, *height=([^,]+)/);
- if(height_data) {
- height_data = height_data[1];
- } else {
- height_data = '315';
- }
- return '' +
- '<iframe ' +
- 'width="' + width_data + '" ' +
- 'height="' + height_data + '" ' +
- 'src="' + video_src + '" ' +
- 'allowfullscreen>' +
- '</iframe>' +
- '';
- } else if(name.match(/^ruby$/i)) {
- var main_text = in_data.match(/^([^,]+)/);
- if(main_text) {
- main_text = main_text[1];
- } else {
- main_text = 'test';
- }
- var ruby_text = in_data.match(/, *ruby=([^,]+)/);
- if(ruby_text) {
- ruby_text = ruby_text[1];
- } else {
- ruby_text = 'test';
- }
- var color_text = in_data.match(/, *color=([^,]+)/);
- if(color_text) {
- color_text = 'color:' + color_text[1];
- } else {
- color_text = '';
- }
- return '' +
- '<ruby>' +
- main_text +
- '<rp>(</rp>' +
- '<rt>' +
- '<span style="' + color_text + '">' + ruby_text + '</span>' +
- '</rt>' +
- '<rp>)</rp>' +
- '</ruby>' +
- '';
- } else if(name.match(/^anchor$/i)) {
- return '<span id="' + in_data + '"></span>';
- } else {
- return all;
- }
- });
- var toc_array = [0, 0, 0, 0, 0, 0];
- var before_data = 0;
- var toc_data = '<div id="toc"><span id="toc_title">TOC</span>\n\n'
- data = data.replace(/\n(={1,6}) ?([^\n]+) (?:={1,6})/g, function(all, num, in_data) {
- num = num.length;
-
- if(before_data > num) {
- var i = num;
- while(1) {
- if(i == 6) {
- break;
- }
- toc_array[i] = 0;
- i += 1;
- }
- }
- before_data = num;
- toc_array[num - 1] += 1;
- num = String(num);
- var toc_num = (toc_array.join('.') + '.').replace(/0\./g, '');
- if(!toc_num.match(/\./)) {
- toc_num += '0.';
- }
- toc_data += '' +
- '<span style="margin-left: ' + String(10 * (toc_num.length / 2) - 10) + 'px;">' +
- '<a href="#s-' + toc_num.replace(/\.$/, '') + '">' + toc_num + '</a> ' + in_data +
- '</span>' +
- '\n' +
- '';
- return '\n<h' + num + ' id="s-' + toc_num.replace(/\.$/, '') + '"><a href="#toc">' + toc_num + '</a> ' + in_data + '</h' + num + '>';
- });
- toc_data += '</div>';
- data = data.replace(/<\/h([0-9])>\n/g, '</h$1>');
- data = data.replace(/\[([^\]]+)\]/g, function(all, name) {
- if(name.match(/^br$/i)) {
- return '\n'
- } else if(name.match(/^목차$/i)) {
- return toc_data;
- } else if(name.match(/^date|datetime$/i)) {
- return get_today();
- } else {
- return all;
- }
- });
- var ref_num = 0;
- var ref_data = '<hr><ul id="footnote_data">';
- var name_ref_data = {};
- data = data.replace(/(?:\[\*([^ \]]*)(?: ([^\]]+))?\]|\[(?:각주|footnote)])/g, function(all, name_data, in_data) {
- if(all.match(/^\[(?:각주|footnote)]$/i)) {
- var new_ref_data = ref_data;
- ref_data = '<hr><ul id="footnote_data">';
-
- return new_ref_data + '</ul>';
- } else {
- ref_num += 1;
- if(name_data) {
- if(in_data) {
- name_ref_data[name_data] = in_data;
- ref_data += '' +
- '<li>' +
- '<a id="fn-' + name_data + '" href="#rfn-' + String(ref_num) + '">(' + name_data + ')</a> ' + in_data + ''
- '</li>' +
- ''
- } else {
- ref_data += '' +
- '<li>' +
- '<a href="#rfn-' + String(ref_num) + '">(' + name_data + ')</a>' +
- '</li>' +
- ''
- }
- } else {
- ref_data += '' +
- '<li>' +
- '<a id="fn-' + String(ref_num) + '" href="#rfn-' + String(ref_num) + '">(' + String(ref_num) + ')</a> ' + in_data + ''
- '</li>' +
- ''
- }
- if(name_data) {
- return '' +
- '<sup>' +
- '<a href="#fn-' + name_data + '" id="rfn-' + String(ref_num) + '" title="' + name_ref_data[name_data].replace(/<([^>]*)>/g, '') + '">' +
- '(' + name_data + ')' +
- '</a>' +
- '</sup>' +
- '';
- } else {
- return '' +
- '<sup>' +
- '<a href="#fn-' + String(ref_num) + '" id="rfn-' + String(ref_num) + '" title="' + in_data.replace(/<([^>]*)>/g, '') + '">' +
- '(' + String(ref_num) + ')' +
- '</a>' +
- '</sup>' +
- '';
- }
- }
- });
- if(ref_data !== '<hr><ul id="footnote_data">') {
- data += ref_data + '</ul>';
- }
- var i = 1;
- while(1) {
- if(nowiki_list['nowiki_' + String(i)]) {
- data = data.replace('<span id="nowiki_' + String(i) + '"></span>', '<code>' + nowiki_list['nowiki_' + String(i)] + '</code>');
- i += 1;
- } else {
- break;
- }
- }
- data = data.replace(/^(\n| )+/g, '');
- data = data.replace(/(\n| )+$/g, '');
- data = data.replace(/\n/g, '<br>');
- data = data.replace(/&/g, '&');
- document.getElementById(target).innerHTML = data;
- i = 0;
- while(1) {
- if(math_list[i]) {
- try {
- katex.render(math_list[i][1], document.getElementById(math_list[i][0]));
- } catch {
- try {
- document.getElementById(math_list[i][0]).innerHTML = '<span style="color: red;">' + math_list[i][1] + '</span>';
- } catch {}
- }
- i += 1;
- } else {
- break;
- }
- }
- i = 0;
- while(1) {
- if(link_list[i]) {
- get_link_state(link_list[i]);
- i += 1;
- } else {
- break;
- }
- }
- i = 0;
- while(1) {
- if(file_list[i]) {
- get_file_state(file_list[i]);
- i += 1;
- } else {
- break;
- }
- }
- render_html("html_render_contect");
- }
|