thread.js 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  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. if(data_i_pas === '') {
  43. data_i_pas = '<br>';
  44. } else {
  45. data_i_pas = data_i_pas.replace(
  46. /&lt;topic_a&gt;((?:(?!&lt;\/topic_a&gt;).)+)&lt;\/topic_a&gt;/g,
  47. '<a href="$1">$1</a>'
  48. );
  49. data_i_pas = data_i_pas.replace(
  50. /&lt;topic_call&gt;@((?:(?!&lt;\/topic_call&gt;).)+)&lt;\/topic_call&gt;/g,
  51. '<a href="/w/user:$1">@$1</a>',
  52. );
  53. }
  54. if(blind === 'O') {
  55. color_b = 'opennamu_comment_blind';
  56. } else {
  57. color_b = 'opennamu_comment_blind_not';
  58. }
  59. if(blind === 'O') {
  60. ip += ' <a href="/admin_log?search=blind%20(code%20' + topic_num + '#' + key + '">(B)</a>';
  61. if(admin === '1') {
  62. ip += ' <a href="javascript:opennamu_do_open_comment(\'' + key + '\');">(O)</a>';
  63. }
  64. }
  65. if(admin === '1' || blind !== 'O') {
  66. ip += ' <a href="/thread/' + topic_num + '/comment/' + key + '/tool">(T)</a>';
  67. }
  68. if(type_do === 'top') {
  69. color_t = 'opennamu_comment_color_red';
  70. } else if(blind === '1') {
  71. color_t = 'opennamu_comment_color_blue';
  72. } else if(blind === 'O') {
  73. color_t = 'opennamu_comment_color_gray';
  74. } else if(ip_o === ip_first) {
  75. color_t = 'opennamu_comment_color_green';
  76. } else {
  77. color_t = 'opennamu_comment_color_default';
  78. }
  79. data_a += '' +
  80. '<table class="opennamu_comment">' +
  81. '<tr>' +
  82. '<td class="' + color_t + '">' +
  83. '<a href="javascript:void(0);" id="' + key + '">#' + key + '</a> ' +
  84. ip +
  85. '<span style="float: right;">' + data_t[key]['date'] + '</span>' +
  86. '</td>' +
  87. '</tr>' +
  88. '<tr>' +
  89. '<td class="' + color_b + '" id="opennamu_comment_data_' + key + '">' +
  90. '<div class="opennamu_comment_scroll">' + data_i_pas + '</div>' +
  91. '</td>' +
  92. '</tr>' +
  93. '</table>' +
  94. '<hr class="main_hr">' +
  95. ''
  96. console.log(where);
  97. document.getElementById(where).innerHTML += data_a;
  98. count += 1;
  99. data_all_js += data_t[key]['data_pas'][1] + '\n';
  100. if(count > 100) {
  101. eval(data_all_js);
  102. count = 0;
  103. data_all_js = '';
  104. }
  105. }
  106. eval(data_all_js);
  107. opennamu_do_ip_parser();
  108. if(type_do === 'top') {
  109. opennamu_do_thread_make(topic_num, 'main', '', 'main_topic');
  110. } else if(type_do === 'main') {
  111. let data_url_v = window.location.hash.replace(/^#/, '');
  112. if(data_url_v !== '') {
  113. if(document.getElementById(data_url_v)) {
  114. document.getElementById(data_url_v).focus();
  115. }
  116. }
  117. opennamu_do_thread_make(topic_num, 're', key_v, where);
  118. } else if(type_do === 're') {
  119. setTimeout(function() {
  120. if(start === 0) {
  121. opennamu_do_thread_make(topic_num, 're', some, where);
  122. } else {
  123. opennamu_do_thread_make(topic_num, 're', key_v, where);
  124. }
  125. }, 2000);
  126. }
  127. }
  128. }
  129. }
  130. function opennamu_do_open_comment(key) {
  131. let element_state = document.getElementById('opennamu_comment_data_' + key).style.display;
  132. if(!element_state || element_state === 'none') {
  133. document.getElementById('opennamu_comment_data_' + key).style.display = 'block';
  134. } else {
  135. document.getElementById('opennamu_comment_data_' + key).style.display = 'none';
  136. }
  137. }
  138. if(window.location.pathname.match(/^\/thread\//)) {
  139. let thread_num = window.location.pathname.match(/^\/thread\/([0-9]+)/)[1];
  140. opennamu_do_thread_make(thread_num);
  141. } else if(window.location.pathname.match(/^\/topic\//)) {
  142. for(let for_a = 0; document.getElementsByClassName('topic_pre')[for_a]; for_a++) {
  143. let thread_num = document.getElementsByClassName('topic_pre')[for_a].id;
  144. thread_num = thread_num.match(/^opennamu_thread_([0-9]+)/)[1];
  145. opennamu_do_thread_make(thread_num, "list", "/normal/1", "opennamu_thread_" + thread_num);
  146. let xhr = new XMLHttpRequest();
  147. xhr.open("GET", "/api/thread/" + thread_num + "/length");
  148. xhr.send();
  149. xhr.onreadystatechange = function() {
  150. if(this.readyState === 4 && this.status === 200) {
  151. let thread_length = JSON.parse(this.responseText)['length'];
  152. if(thread_length !== '1') {
  153. opennamu_do_thread_make(thread_num, "list", "/normal/" + thread_length, "opennamu_thread_back_" + thread_num);
  154. }
  155. }
  156. }
  157. }
  158. }