load_something.js 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. function load_user_info(name) {
  2. var url = "/api/user_info/" + encodeURI(name) + "?render=1";
  3. var xhr = new XMLHttpRequest();
  4. xhr.open("GET", url, true);
  5. xhr.send(null);
  6. xhr.onreadystatechange = function() {
  7. if(this.readyState === 4 && this.status === 200) {
  8. document.getElementById('get_user_info').innerHTML += JSON.parse(this.responseText)['data'];
  9. }
  10. }
  11. }
  12. function load_ver() {
  13. var url = "/api/version";
  14. var xhr = new XMLHttpRequest();
  15. xhr.open("GET", url, true);
  16. xhr.send();
  17. xhr.onreadystatechange = function() {
  18. if(this.readyState === 4 && this.status === 200) {
  19. let get_data = JSON.parse(this.responseText);
  20. document.getElementById('ver_send_2').innerHTML = get_data['version'];
  21. let url_2 = 'https://raw.githubusercontent.com/openNAMU/openNAMU/' + get_data['build'] + '/version.json';
  22. var xhr_2 = new XMLHttpRequest();
  23. xhr_2.open("GET", url_2, true);
  24. xhr_2.send();
  25. xhr_2.onreadystatechange = function() {
  26. if(this.readyState === 4 && this.status === 200) {
  27. document.getElementById('ver_send').innerHTML += JSON.parse(this.responseText)['beta']['r_ver'];
  28. document.getElementById('ver_send').style.display = "list-item";
  29. }
  30. }
  31. }
  32. }
  33. }
  34. function do_skin_ver_check() {
  35. var url = "/api/skin_info?all=true";
  36. var xhr = new XMLHttpRequest();
  37. xhr.open("GET", url, true);
  38. xhr.send();
  39. xhr.onreadystatechange = function() {
  40. if(this.readyState === 4 && this.status === 200) {
  41. var json_data = JSON.parse(this.responseText);
  42. for(var key in json_data) {
  43. document.getElementById('ver_send_3').innerHTML += '<li>' +
  44. json_data[key]['name'] + ' : ' + json_data[key]['skin_ver'] +
  45. (json_data[key]['lastest_version'] ? ' (' + json_data[key]['lastest_version']['skin_ver'] + ')' : '') +
  46. '</li>'
  47. }
  48. }
  49. }
  50. }
  51. function do_twofa_check(init = 0) {
  52. let twofa_option = document.getElementById('twofa_check_input');
  53. let twofa_option_num = twofa_option.options.selectedIndex;
  54. let twofa_select_data = twofa_option.options[twofa_option_num].value;
  55. if(twofa_select_data === 'on') {
  56. document.getElementById('fa_plus_content').style.display = "block";
  57. } else {
  58. document.getElementById('fa_plus_content').style.display = "none";
  59. }
  60. }
  61. function send_render(i = 0) {
  62. let get_class = document.getElementsByClassName('send_content')[i];
  63. if(get_class) {
  64. send_render(i + 1);
  65. let data = get_class.innerHTML;
  66. if(data === '&lt;br&gt;') {
  67. document.getElementsByClassName('send_content')[i].innerHTML = '<br>';
  68. } else {
  69. data = data.replace(/javascript:/i, '');
  70. data = data.replace(/&lt;a(?:(?:(?!&gt;).)*)&gt;((?:(?!&lt;\/a&gt;).)+)&lt;\/a&gt;/g, function(x, x_1) {
  71. x_1_org = x_1.replace('&lt;', '<').replace('&gt;', '>');
  72. return '<a href="/w/' + encodeURIComponent(x_1_org) + '">' + x_1 + '</a>';
  73. });
  74. document.getElementsByClassName('send_content')[i].innerHTML = data;
  75. }
  76. }
  77. }
  78. function simple_render(name_ele) {
  79. var skin_set_data = document.getElementById(name_ele).innerHTML;
  80. // 목차 구현
  81. var toc_all_data = '<div id="toc"><span id="toc_title">TOC</span><br>';
  82. var split_toc;
  83. var toc_data;
  84. i = 1;
  85. while(1) {
  86. toc_data = skin_set_data.match(/<h[1-6]>([^<>]+)<\/h[1-6]>/);
  87. if(toc_data) {
  88. split_toc = toc_data[1].match(/^([^ ]+)(.+)/);
  89. toc_all_data += '' +
  90. '<br>' +
  91. '<span style="margin-left: ' + String(((toc_data[1].match(/\./g) || []).length - 1) * 10) + 'px;">' +
  92. '<a href="#toc_' + String(i) + '">' + split_toc[1] + '</a>' + split_toc[2] +
  93. '</span>' +
  94. '';
  95. skin_set_data = skin_set_data.replace(
  96. /<(h[1-6])>([^<>]+)<\/h[1-6]>/,
  97. '<$1 id="toc_' + String(i) + '"><a href="#toc">' + split_toc[1] + '</a>' + split_toc[2] + '</$1>'
  98. );
  99. i += 1;
  100. } else {
  101. break;
  102. }
  103. }
  104. skin_set_data = toc_all_data + '</div>' + skin_set_data;
  105. // 각주 구현
  106. var note_list = {};
  107. var plus_note;
  108. i = 1;
  109. while(1) {
  110. toc_data = skin_set_data.match(/<sup>([^<>]+)<\/sup>/);
  111. if(toc_data) {
  112. if(!note_list[toc_data[1]]) {
  113. note_list[toc_data[1]] = [String(i), 0];
  114. } else {
  115. note_list[toc_data[1]][1] += 1;
  116. }
  117. if(note_list[toc_data[1]][1] != 0) {
  118. plus_note = '_' + String(note_list[toc_data[1]][1]);
  119. } else {
  120. plus_note = '';
  121. }
  122. skin_set_data = skin_set_data.replace(
  123. /<sup>([^<>]+)<\/sup>/,
  124. '<sup><a id="note_' + note_list[toc_data[1]][0] + plus_note + '" href="#note_' + note_list[toc_data[1]][0] + '_end">$1</a></sup>'
  125. );
  126. i += 1;
  127. } else {
  128. break;
  129. }
  130. }
  131. document.getElementById(name_ele).innerHTML = skin_set_data;
  132. }
  133. function ie_end_support() {
  134. if(document.currentScript === undefined) {
  135. window.location = 'microsoft-edge:' + window.location;
  136. setTimeout(function() {
  137. window.location = 'https://go.microsoft.com/fwlink/?linkid=2135547';
  138. }, 1);
  139. }
  140. }
  141. ie_end_support();