thread.js 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. // 좀 더 개선 필요
  2. // use strict 적용 필요 (eval 동작에 문제 있음)
  3. function opennamu_do_thread_make(topic_num, type_do = 'top', some = '', where = 'top_topic') {
  4. let url = '';
  5. if(type_do === 'top') {
  6. url = "/api/thread/" + topic_num + "/top";
  7. } else if(type_do === 'main') {
  8. url = "/api/thread/" + topic_num;
  9. } else {
  10. url = "/api/thread/" + topic_num + some;
  11. }
  12. let xhr = new XMLHttpRequest();
  13. xhr.open("GET", url);
  14. xhr.send();
  15. xhr.onreadystatechange = function() {
  16. if(this.readyState === 4 && this.status === 200) {
  17. let data_t = JSON.parse(this.responseText);
  18. let start = 0;
  19. let key_v = '/normal/1';
  20. let admin = '';
  21. let ip_first = '';
  22. let data_all = '';
  23. let data_all_js = '';
  24. let count = 0;
  25. for(let key in data_t) {
  26. let data_a = '';
  27. if(start === 0) {
  28. admin = data_t['data_main']['admin'];
  29. ip_first = data_t['data_main']['ip_first'];
  30. start = 1;
  31. }
  32. if(key === 'data_main') {
  33. continue;
  34. }
  35. key_v = '/normal/' + String(Number(key) + 1);
  36. let color_b = '';
  37. let color_t = '';
  38. let ip = data_t[key]['ip_pas'];
  39. let ip_o = data_t[key]['ip'];
  40. let blind = data_t[key]['blind'];
  41. let data_i_pas = data_t[key]['data_pas'][0];
  42. let data_get_list = [];
  43. if(data_i_pas === '') {
  44. data_i_pas = '<br>';
  45. } else {
  46. let load_thread_regex = /&lt;topic_a&gt;((?:(?!&lt;\/topic_a&gt;).)+)&lt;\/topic_a&gt;/g;
  47. data_get_list = data_i_pas.match(load_thread_regex);
  48. data_i_pas = data_i_pas.replace(load_thread_regex, '<a href="$1">$1</a>');
  49. data_i_pas = data_i_pas.replace(/&lt;topic_call&gt;@((?:(?!&lt;\/topic_call&gt;).)+)&lt;\/topic_call&gt;/g, '<a href="/w/user:$1">@$1</a>');
  50. }
  51. if(blind === 'O') {
  52. color_b = 'opennamu_comment_blind';
  53. } else {
  54. color_b = 'opennamu_comment_blind_not';
  55. }
  56. if(blind === 'O') {
  57. ip += ' <a href="/admin_log?search=blind%20(code%20' + topic_num + '#' + key + '">(B)</a>';
  58. if(admin === '1') {
  59. ip += ' <a href="javascript:opennamu_do_open_comment(\'' + key + '\');">(O)</a>';
  60. }
  61. }
  62. if(admin === '1' || blind !== 'O') {
  63. ip += ' <a href="/thread/' + topic_num + '/comment/' + key + '/tool">(T)</a>';
  64. }
  65. if(type_do === 'top') {
  66. color_t = 'opennamu_comment_color_red';
  67. } else if(blind === '1') {
  68. color_t = 'opennamu_comment_color_blue';
  69. } else if(blind === 'O') {
  70. color_t = 'opennamu_comment_color_gray';
  71. } else if(ip_o === ip_first) {
  72. color_t = 'opennamu_comment_color_green';
  73. } else {
  74. color_t = 'opennamu_comment_color_default';
  75. }
  76. data_a += '' +
  77. '<table class="opennamu_comment">' +
  78. '<tr>' +
  79. '<td class="' + color_t + '">' +
  80. '<a href="javascript:void(0);" id="' + key + '">#' + key + '</a> ' +
  81. ip +
  82. '<span style="float: right;">' + data_t[key]['date'] + '</span>' +
  83. '</td>' +
  84. '</tr>' +
  85. '<tr>' +
  86. '<td class="' + color_b + '" id="opennamu_comment_data_' + key + '">' +
  87. '<div class="opennamu_comment_scroll">' + data_i_pas + '</div>' +
  88. '</td>' +
  89. '</tr>' +
  90. '</table>' +
  91. '<hr class="main_hr">' +
  92. ''
  93. document.getElementById(where).innerHTML += data_a;
  94. count += 1;
  95. data_all_js += data_t[key]['data_pas'][1] + '\n';
  96. if(count > 100) {
  97. eval(data_all_js);
  98. count = 0;
  99. data_all_js = '';
  100. }
  101. }
  102. eval(data_all_js);
  103. opennamu_do_ip_parser();
  104. if(type_do === 'top') {
  105. opennamu_do_thread_make(topic_num, 'main', '', 'main_topic');
  106. } else if(type_do === 'main') {
  107. let data_url_v = window.location.hash.replace(/^#/, '');
  108. if(data_url_v !== '') {
  109. if(document.getElementById(data_url_v)) {
  110. document.getElementById(data_url_v).focus();
  111. }
  112. }
  113. opennamu_do_thread_make(topic_num, 're', key_v, where);
  114. } else if(type_do === 're') {
  115. setTimeout(function() {
  116. if(start === 0) {
  117. opennamu_do_thread_make(topic_num, 're', some, where);
  118. } else {
  119. opennamu_do_thread_make(topic_num, 're', key_v, where);
  120. }
  121. }, 2000);
  122. }
  123. }
  124. }
  125. }
  126. function opennamu_do_open_comment(key) {
  127. let element_state = document.getElementById('opennamu_comment_data_' + key).style.display;
  128. if(!element_state || element_state === 'none') {
  129. document.getElementById('opennamu_comment_data_' + key).style.display = 'block';
  130. } else {
  131. document.getElementById('opennamu_comment_data_' + key).style.display = 'none';
  132. }
  133. }
  134. if(window.location.pathname.match(/^\/(thread|thread_preview)\//)) {
  135. let thread_num = window.location.pathname.match(/^\/(?:thread|thread_preview)\/([0-9]+)/)[1];
  136. opennamu_do_thread_make(thread_num);
  137. } else if(window.location.pathname.match(/^\/topic\//)) {
  138. for(let for_a = 0; document.getElementsByClassName('topic_pre')[for_a]; for_a++) {
  139. let thread_num = document.getElementsByClassName('topic_pre')[for_a].id;
  140. thread_num = thread_num.match(/^opennamu_thread_([0-9]+)/)[1];
  141. opennamu_do_thread_make(thread_num, "list", "/normal/1", "opennamu_thread_" + thread_num);
  142. let xhr = new XMLHttpRequest();
  143. xhr.open("GET", "/api/thread/" + thread_num + "/length");
  144. xhr.send();
  145. xhr.onreadystatechange = function() {
  146. if(this.readyState === 4 && this.status === 200) {
  147. let thread_length = JSON.parse(this.responseText)['length'];
  148. if(thread_length !== '1') {
  149. opennamu_do_thread_make(thread_num, "list", "/normal/" + thread_length, "opennamu_thread_back_" + thread_num);
  150. }
  151. }
  152. }
  153. }
  154. }