thread.js 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  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="/list/admin/auth_use/' + opennamu_do_url_encode('blind (code ' + topic_num + '#' + key) + '/1">(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="#thread_shortcut" 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. if(type_do === 'top') {
  104. opennamu_do_thread_make(topic_num, 'main', '', 'main_topic');
  105. } else if(type_do === 'main') {
  106. let data_url_v = window.location.hash.replace(/^#/, '');
  107. if(data_url_v !== '') {
  108. if(document.getElementById(data_url_v)) {
  109. document.getElementById(data_url_v).focus();
  110. }
  111. }
  112. opennamu_do_thread_make(topic_num, 're', key_v, where);
  113. } else if(type_do === 're') {
  114. setTimeout(function() {
  115. if(start === 0) {
  116. opennamu_do_thread_make(topic_num, 're', some, where);
  117. } else {
  118. opennamu_do_thread_make(topic_num, 're', key_v, where);
  119. }
  120. }, 2000);
  121. }
  122. }
  123. }
  124. }
  125. function opennamu_do_open_comment(key) {
  126. let element_state = document.getElementById('opennamu_comment_data_' + key).style.display;
  127. if(!element_state || element_state === 'none') {
  128. document.getElementById('opennamu_comment_data_' + key).style.display = 'block';
  129. } else {
  130. document.getElementById('opennamu_comment_data_' + key).style.display = 'none';
  131. }
  132. }
  133. if(window.location.pathname.match(/^\/(thread|thread_preview)\//)) {
  134. let thread_num = window.location.pathname.match(/^\/(?:thread|thread_preview)\/([0-9]+)/)[1];
  135. opennamu_do_thread_make(thread_num);
  136. } else if(window.location.pathname.match(/^\/topic\//)) {
  137. for(let for_a = 0; document.getElementsByClassName('topic_pre')[for_a]; for_a++) {
  138. let thread_num = document.getElementsByClassName('topic_pre')[for_a].id;
  139. thread_num = thread_num.match(/^opennamu_thread_([0-9]+)/)[1];
  140. opennamu_do_thread_make(thread_num, "list", "/normal/1", "opennamu_thread_" + thread_num);
  141. let xhr = new XMLHttpRequest();
  142. xhr.open("GET", "/api/thread/" + thread_num + "/length");
  143. xhr.send();
  144. xhr.onreadystatechange = function() {
  145. if(this.readyState === 4 && this.status === 200) {
  146. let thread_length = JSON.parse(this.responseText)['length'];
  147. if(thread_length !== '1') {
  148. opennamu_do_thread_make(thread_num, "list", "/normal/" + thread_length, "opennamu_thread_back_" + thread_num);
  149. }
  150. }
  151. }
  152. }
  153. }