topic.js 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  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_blind() {
  17. let do_true = 0;
  18. for(let for_a = 0; for_a < document.getElementsByClassName("opennamu_blind_button").length; for_a++) {
  19. let id = document.getElementsByClassName("opennamu_blind_button")[for_a].id;
  20. id = id.replace(/^opennamu_blind_/, '');
  21. id = id.split('_');
  22. let checked = document.getElementsByClassName("opennamu_blind_button")[for_a].checked;
  23. if(checked) {
  24. fetch("/thread/" + id[0] + '/comment/' + id[1] + '/blind', { method : 'GET' });
  25. do_true = 1;
  26. }
  27. }
  28. if(do_true === 1) {
  29. history.go(0);
  30. }
  31. }
  32. function opennamu_get_thread_ui(user_id, date, data, code, color = '', blind = '', add_style = '', topic_num = '') {
  33. let color_b, class_b;
  34. if(blind == 'O') {
  35. color_b = data == '' ? 'opennamu_comment_blind' : 'opennamu_comment_blind_admin';
  36. class_b = 'opennamu_comment_blind_js';
  37. } else {
  38. color_b = 'opennamu_comment_blind_not';
  39. class_b = '';
  40. }
  41. let admin_check_box = ''
  42. if(topic_num != '') {
  43. admin_check_box = '<input type="checkbox" class="opennamu_blind_button" id="opennamu_blind_' + topic_num + '_' + code + '">';
  44. }
  45. return `
  46. <span class="` + class_b + `">
  47. <table class="opennamu_comment" style="` + add_style + `">
  48. <tr>
  49. <td class="opennamu_comment_color_` + color + `">
  50. ` + admin_check_box + `
  51. <a href="#thread_shortcut" id="` + code + `">#` + code + `</a>
  52. ` + user_id + `
  53. <span style="float: right;">` + date + `</span>
  54. </td>
  55. </tr>
  56. <tr>
  57. <td class="` + color_b + ` opennamu_comment_data_main" id="thread_` + code + `">
  58. ` + data + `
  59. </td>
  60. </tr>
  61. </table>
  62. <hr class="main_hr">
  63. </span>
  64. `;
  65. }
  66. function opennamu_get_thread(topic_num = "", do_type = "") {
  67. let url, to_obj, color;
  68. if(do_type === "top") {
  69. url = "/api/thread/" + topic_num + "/top";
  70. to_obj = 'opennamu_top_thread';
  71. color = 'red';
  72. } else {
  73. url = "/api/thread/" + topic_num;
  74. to_obj = 'opennamu_main_thread';
  75. color = 'default';
  76. }
  77. fetch(url).then(function(res) {
  78. return res.json();
  79. }).then(function(data) {
  80. let end_data = '';
  81. let end_render = [];
  82. let lang = data["language"];
  83. data = data["data"];
  84. let first = '';
  85. for(let for_a = 0; for_a < data.length; for_a++) {
  86. if(first === '') {
  87. first = data[for_a]["ip"];
  88. }
  89. let real_color = color;
  90. if(color !== 'red') {
  91. if(data[for_a]["blind"] === '1') {
  92. real_color = 'blue';
  93. } else if(first === data[for_a]["ip"]) {
  94. real_color = 'green';
  95. } else {
  96. real_color = 'default';
  97. }
  98. }
  99. let date = '<a href="/thread/' + topic_num + '/comment/' + data[for_a]["id"] + '/tool">(' + lang["tool"] + ')</a> ' + data[for_a]["date"];
  100. let render_button = ' <a href="javascript:void(0);" id="opennamu_' + color + '_thread_render_' + data[for_a]["id"] + '_button">(' + lang["render"] + ")</a>"
  101. let render_data = data[for_a]["data"] !== "" ? data[for_a]["data"] : "[br]";
  102. end_data += opennamu_get_thread_ui(
  103. data[for_a]["ip_render"] + render_button,
  104. date,
  105. '<div class="opennamu_comment_scroll" id="opennamu_' + color + '_thread_render_' + data[for_a]["id"] + '">' + opennamu_xss_filter(render_data) + '</div>',
  106. data[for_a]["id"],
  107. real_color,
  108. data[for_a]["blind"],
  109. '',
  110. topic_num
  111. )
  112. end_render.push([
  113. render_data,
  114. data[for_a]["id"]
  115. ]);
  116. }
  117. document.getElementById(to_obj).innerHTML = end_data;
  118. for(let for_a = 0; for_a < end_render.length; for_a++) {
  119. document.getElementById('opennamu_' + color + '_thread_render_' + end_render[for_a][1] + '_button').addEventListener("click", function() {
  120. opennamu_do_render(
  121. 'opennamu_' + color + '_thread_render_' + end_render[for_a][1],
  122. "thread_" + topic_num + "_" + color + "_" + end_render[for_a][1],
  123. end_render[for_a][0],
  124. 'thread'
  125. );
  126. });
  127. }
  128. });
  129. }