load_something.js 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  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. var get_class = document.getElementsByClassName('send_content')[i];
  63. if(get_class) {
  64. send_render(i + 1);
  65. var 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;((?:(?!&lt;\/a&gt;).)+)&lt;\/a&gt;/g, function(x, x_1) {
  71. return '<a href="/w/' + encodeURIComponent(x_1) + '">' + x_1 + '</a>';
  72. });
  73. document.getElementsByClassName('send_content')[i].innerHTML = data;
  74. }
  75. }
  76. }
  77. function simple_render(name_ele) {
  78. var skin_set_data = document.getElementById(name_ele).innerHTML;
  79. // 목차 구현
  80. var toc_all_data = '<div id="toc"><span id="toc_title">TOC</span><br>';
  81. var split_toc;
  82. var toc_data;
  83. i = 1;
  84. while(1) {
  85. toc_data = skin_set_data.match(/<h[1-6]>([^<>]+)<\/h[1-6]>/);
  86. if(toc_data) {
  87. split_toc = toc_data[1].match(/^([^ ]+)(.+)/);
  88. toc_all_data += '' +
  89. '<br>' +
  90. '<span style="margin-left: ' + String(((toc_data[1].match(/\./g) || []).length - 1) * 10) + 'px;">' +
  91. '<a href="#toc_' + String(i) + '">' + split_toc[1] + '</a>' + split_toc[2] +
  92. '</span>' +
  93. '';
  94. skin_set_data = skin_set_data.replace(
  95. /<(h[1-6])>([^<>]+)<\/h[1-6]>/,
  96. '<$1 id="toc_' + String(i) + '"><a href="#toc">' + split_toc[1] + '</a>' + split_toc[2] + '</$1>'
  97. );
  98. i += 1;
  99. } else {
  100. break;
  101. }
  102. }
  103. skin_set_data = toc_all_data + '</div>' + skin_set_data;
  104. // 각주 구현
  105. var note_list = {};
  106. var plus_note;
  107. i = 1;
  108. while(1) {
  109. toc_data = skin_set_data.match(/<sup>([^<>]+)<\/sup>/);
  110. if(toc_data) {
  111. if(!note_list[toc_data[1]]) {
  112. note_list[toc_data[1]] = [String(i), 0];
  113. } else {
  114. note_list[toc_data[1]][1] += 1;
  115. }
  116. if(note_list[toc_data[1]][1] != 0) {
  117. plus_note = '_' + String(note_list[toc_data[1]][1]);
  118. } else {
  119. plus_note = '';
  120. }
  121. skin_set_data = skin_set_data.replace(
  122. /<sup>([^<>]+)<\/sup>/,
  123. '<sup><a id="note_' + note_list[toc_data[1]][0] + plus_note + '" href="#note_' + note_list[toc_data[1]][0] + '_end">$1</a></sup>'
  124. );
  125. i += 1;
  126. } else {
  127. break;
  128. }
  129. }
  130. document.getElementById(name_ele).innerHTML = skin_set_data;
  131. }
  132. function ie_end_support() {
  133. if(document.currentScript === undefined) {
  134. window.location = 'microsoft-edge:' + window.location;
  135. setTimeout(function() {
  136. window.location = 'https://go.microsoft.com/fwlink/?linkid=2135547';
  137. }, 1);
  138. }
  139. }
  140. ie_end_support();