topic.js 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214
  1. "use strict";
  2. function opennamu_do_remove_blind_thread() {
  3. const style = document.querySelector('#opennamu_remove_blind');
  4. if(style !== null) {
  5. if(style.innerHTML !== "") {
  6. style.innerHTML = '';
  7. } else {
  8. style.innerHTML = `
  9. .opennamu_comment_blind_js {
  10. display: none;
  11. }
  12. `;
  13. }
  14. }
  15. }
  16. function opennamu_thread_delete() {
  17. let lang_data = new FormData();
  18. lang_data.append('data', 'delete');
  19. fetch('/api/lang', {
  20. method : 'post',
  21. body : lang_data,
  22. }).then(function(res) {
  23. return res.json();
  24. }).then(function(lang) {
  25. lang = lang["data"];
  26. let check_list = [];
  27. let check_list_str = '';
  28. for(let for_a = 0; for_a < document.getElementsByClassName("opennamu_blind_button").length; for_a++) {
  29. let id = document.getElementsByClassName("opennamu_blind_button")[for_a].id;
  30. id = id.replace(/^opennamu_blind_/, '');
  31. id = id.split('_');
  32. let checked = document.getElementsByClassName("opennamu_blind_button")[for_a].checked;
  33. if(checked) {
  34. check_list.push([id[0], id[1]]);
  35. check_list_str += '#' + id[1] + ' ';
  36. }
  37. }
  38. let check = confirm(check_list_str + lang[0]);
  39. if(check === true) {
  40. for(let for_a = 0; for_a < check_list.length; for_a++) {
  41. fetch("/thread/" + check_list[for_a][0] + '/comment/' + check_list[for_a][1] + '/delete', { method : 'POST' });
  42. }
  43. if(check_list.length > 0) {
  44. history.go(0);
  45. }
  46. }
  47. });
  48. }
  49. function opennamu_thread_blind() {
  50. let do_true = 0;
  51. for(let for_a = 0; for_a < document.getElementsByClassName("opennamu_blind_button").length; for_a++) {
  52. let id = document.getElementsByClassName("opennamu_blind_button")[for_a].id;
  53. id = id.replace(/^opennamu_blind_/, '');
  54. id = id.split('_');
  55. let checked = document.getElementsByClassName("opennamu_blind_button")[for_a].checked;
  56. if(checked) {
  57. fetch("/thread/" + id[0] + '/comment/' + id[1] + '/blind', { method : 'GET' });
  58. do_true = 1;
  59. }
  60. }
  61. if(do_true === 1) {
  62. history.go(0);
  63. }
  64. }
  65. function opennamu_get_thread_ui(user_id, date, data, code, color = '', blind = '', add_style = '', topic_num = '') {
  66. let color_b, class_b;
  67. if(blind == 'O') {
  68. color_b = data == '' ? 'opennamu_comment_blind' : 'opennamu_comment_blind_admin';
  69. class_b = 'opennamu_comment_blind_js';
  70. } else {
  71. color_b = 'opennamu_comment_blind_not';
  72. class_b = '';
  73. }
  74. let admin_check_box = ''
  75. if(topic_num != '') {
  76. admin_check_box = '<input type="checkbox" class="opennamu_blind_button" id="opennamu_blind_' + topic_num + '_' + code + '">';
  77. }
  78. return `
  79. <span class="` + class_b + `">
  80. <table class="opennamu_comment" style="` + add_style + `">
  81. <tr>
  82. <td class="opennamu_comment_color_` + color + `">
  83. ` + admin_check_box + `
  84. <a href="#thread_shortcut" id="` + code + `">#` + code + `</a>
  85. ` + user_id + `
  86. <span style="float: right;">` + date + `</span>
  87. </td>
  88. </tr>
  89. <tr>
  90. <td class="` + color_b + ` opennamu_comment_data_main" id="thread_` + code + `">
  91. ` + data + `
  92. </td>
  93. </tr>
  94. </table>
  95. <hr class="main_hr">
  96. </span>
  97. `;
  98. }
  99. function opennamu_get_new_thread(topic_num = "", thread_num = "") {
  100. let get_thread = setInterval(function() {
  101. if(!document.getElementById('opennamu_default_thread_render_' + thread_num)) {
  102. opennamu_get_thread(topic_num, "", thread_num);
  103. } else {
  104. opennamu_get_new_thread(topic_num, String(Number(thread_num) + 1));
  105. clearInterval(get_thread);
  106. }
  107. }, 3000);
  108. }
  109. function opennamu_get_thread(topic_num = "", do_type = "", thread_num = "") {
  110. let url, to_obj, color;
  111. if(do_type === "top") {
  112. url = "/api/thread/" + topic_num + "/top";
  113. to_obj = 'opennamu_top_thread';
  114. color = 'red';
  115. } else {
  116. if(thread_num === "") {
  117. url = "/api/thread/" + topic_num;
  118. } else {
  119. url = "/api/thread/" + topic_num + "/" + thread_num + "/" + thread_num;
  120. }
  121. to_obj = 'opennamu_main_thread';
  122. color = 'default';
  123. }
  124. fetch(url).then(function(res) {
  125. return res.json();
  126. }).then(function(data) {
  127. if(data["data"].length !== 0) {
  128. let end_data = '';
  129. let end_render = [];
  130. let lang = data["language"];
  131. data = data["data"];
  132. let first = '';
  133. for(let for_a = 0; for_a < data.length; for_a++) {
  134. if(first === '') {
  135. first = data[for_a]["ip"];
  136. }
  137. let real_color = color;
  138. if(color !== 'red') {
  139. if(data[for_a]["blind"] === '1') {
  140. real_color = 'blue';
  141. } else if(first === data[for_a]["ip"]) {
  142. real_color = 'green';
  143. } else {
  144. real_color = 'default';
  145. }
  146. }
  147. let date = '<a href="/thread/' + topic_num + '/comment/' + data[for_a]["id"] + '/tool">(' + lang["tool"] + ')</a> ' + data[for_a]["date"];
  148. let render_data = data[for_a]["data"] !== "" ? data[for_a]["data"] : "[br]";
  149. end_data += opennamu_get_thread_ui(
  150. data[for_a]["ip_render"],
  151. date,
  152. '<div class="opennamu_comment_scroll" id="opennamu_' + color + '_thread_render_' + data[for_a]["id"] + '">' + opennamu_xss_filter(render_data) + '</div>',
  153. data[for_a]["id"],
  154. real_color,
  155. data[for_a]["blind"],
  156. '',
  157. topic_num
  158. )
  159. end_render.push([
  160. render_data,
  161. data[for_a]["id"]
  162. ]);
  163. }
  164. if(do_type === "" && thread_num === "") {
  165. opennamu_get_new_thread(topic_num, String(Number(data[data.length - 1]["id"]) + 1));
  166. }
  167. document.getElementById(to_obj).innerHTML += end_data;
  168. for(let for_a = 0; for_a < end_render.length; for_a++) {
  169. let observer = new IntersectionObserver(entries => {
  170. entries.forEach(entry => {
  171. if(entry.isIntersecting) {
  172. opennamu_do_render(
  173. 'opennamu_' + color + '_thread_render_' + end_render[for_a][1],
  174. end_render[for_a][0],
  175. '',
  176. 'thread'
  177. );
  178. observer.unobserve(entry.target);
  179. }
  180. });
  181. });
  182. observer.observe(document.getElementById('opennamu_' + color + '_thread_render_' + end_render[for_a][1]));
  183. }
  184. }
  185. });
  186. }