load_something.js 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  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. opennamu_do_ip_parser();
  10. }
  11. }
  12. }
  13. function do_skin_ver_check() {
  14. var url = "/api/skin_info?all=true";
  15. var xhr = new XMLHttpRequest();
  16. xhr.open("GET", url, true);
  17. xhr.send();
  18. xhr.onreadystatechange = function() {
  19. if(this.readyState === 4 && this.status === 200) {
  20. var json_data = JSON.parse(this.responseText);
  21. for(var key in json_data) {
  22. document.getElementById('ver_send_3').innerHTML += '<li>' +
  23. json_data[key]['name'] + ' : ' + json_data[key]['skin_ver'] +
  24. (json_data[key]['lastest_version'] ? ' (' + json_data[key]['lastest_version']['skin_ver'] + ')' : '') +
  25. '</li>'
  26. }
  27. }
  28. }
  29. }
  30. function do_twofa_check(init = 0) {
  31. let twofa_option = document.getElementById('twofa_check_input');
  32. let twofa_option_num = twofa_option.options.selectedIndex;
  33. let twofa_select_data = twofa_option.options[twofa_option_num].value;
  34. if(twofa_select_data === 'on') {
  35. document.getElementById('fa_plus_content').style.display = "block";
  36. } else {
  37. document.getElementById('fa_plus_content').style.display = "none";
  38. }
  39. }
  40. function send_render(i = 0) {
  41. let get_class = document.getElementsByClassName('send_content')[i];
  42. if(get_class) {
  43. send_render(i + 1);
  44. let data = get_class.innerHTML;
  45. if(data === '&lt;br&gt;') {
  46. document.getElementsByClassName('send_content')[i].innerHTML = '<br>';
  47. } else {
  48. data = data.replace(/javascript:/i, '');
  49. data = data.replace(/&lt;a(?:(?:(?!&gt;).)*)&gt;((?:(?!&lt;\/a&gt;).)+)&lt;\/a&gt;/g, function(x, x_1) {
  50. x_1_org = x_1.replace('&lt;', '<').replace('&gt;', '>');
  51. return '<a href="/w/' + encodeURIComponent(x_1_org) + '">' + x_1 + '</a>';
  52. });
  53. document.getElementsByClassName('send_content')[i].innerHTML = data;
  54. }
  55. }
  56. }
  57. function simple_render(name_ele) {
  58. var skin_set_data = document.getElementById(name_ele).innerHTML;
  59. // 목차 구현
  60. var toc_all_data = '<div id="toc"><span id="toc_title">TOC</span><br>';
  61. var split_toc;
  62. var toc_data;
  63. i = 1;
  64. while(1) {
  65. toc_data = skin_set_data.match(/<h[1-6]>([^<>]+)<\/h[1-6]>/);
  66. if(toc_data) {
  67. split_toc = toc_data[1].match(/^([^ ]+)(.+)/);
  68. toc_all_data += '' +
  69. '<br>' +
  70. '<span style="margin-left: ' + String(((toc_data[1].match(/\./g) || []).length - 1) * 10) + 'px;">' +
  71. '<a href="#toc_' + String(i) + '">' + split_toc[1] + '</a>' + split_toc[2] +
  72. '</span>' +
  73. '';
  74. skin_set_data = skin_set_data.replace(
  75. /<(h[1-6])>([^<>]+)<\/h[1-6]>/,
  76. '<$1 id="toc_' + String(i) + '"><a href="#toc">' + split_toc[1] + '</a>' + split_toc[2] + '</$1>'
  77. );
  78. i += 1;
  79. } else {
  80. break;
  81. }
  82. }
  83. skin_set_data = toc_all_data + '</div>' + skin_set_data;
  84. // 각주 구현
  85. var note_list = {};
  86. var plus_note;
  87. i = 1;
  88. while(1) {
  89. toc_data = skin_set_data.match(/<sup>([^<>]+)<\/sup>/);
  90. if(toc_data) {
  91. if(!note_list[toc_data[1]]) {
  92. note_list[toc_data[1]] = [String(i), 0];
  93. } else {
  94. note_list[toc_data[1]][1] += 1;
  95. }
  96. if(note_list[toc_data[1]][1] != 0) {
  97. plus_note = '_' + String(note_list[toc_data[1]][1]);
  98. } else {
  99. plus_note = '';
  100. }
  101. skin_set_data = skin_set_data.replace(
  102. /<sup>([^<>]+)<\/sup>/,
  103. '<sup><a id="note_' + note_list[toc_data[1]][0] + plus_note + '" href="#note_' + note_list[toc_data[1]][0] + '_end">$1</a></sup>'
  104. );
  105. i += 1;
  106. } else {
  107. break;
  108. }
  109. }
  110. document.getElementById(name_ele).innerHTML = skin_set_data;
  111. }