render.js 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. "use strict";
  2. function opennamu_heading_folding(data, element = '') {
  3. let fol = document.getElementById(data);
  4. if(fol.style.display === '' || fol.style.display === 'inline-block' || fol.style.display === 'block') {
  5. document.getElementById(data).style.display = 'none';
  6. } else {
  7. document.getElementById(data).style.display = 'block';
  8. }
  9. if(element !== '') {
  10. console.log(element.innerHTML);
  11. if(element.innerHTML !== '⊖') {
  12. element.innerHTML = '⊖';
  13. } else {
  14. element.innerHTML = '⊕';
  15. }
  16. }
  17. }
  18. function opennamu_do_render_html(name = '') {
  19. if(document.getElementById(name)) {
  20. let data = document.getElementById(name).innerHTML;
  21. let src_list = ['www.youtube.com', 'www.google.com', 'play-tv.kakao.com'];
  22. let t_data = [
  23. 'b', 'i', 's', 'del', 'strong', 'bold', 'em', 'sub', 'sup',
  24. 'div', 'span',
  25. 'a',
  26. 'iframe'
  27. ];
  28. for(let key in t_data) {
  29. let patt = new RegExp(
  30. '<' + t_data[key] + '( (?:(?:(?!>).)+))?>((?:(?!<\/' + t_data[key] + '>).)*)<\/' + t_data[key] + '>',
  31. 'ig'
  32. );
  33. data = data.replace(patt, function(full, in_data, in_data_2) {
  34. if(['b', 'i', 's', 'del', 'strong', 'bold', 'em', 'sub', 'sup'].includes(t_data[key])) {
  35. return '<' + t_data[key] + '>' + in_data_2 + '</' + t_data[key] + '>'
  36. } else if(t_data[key] === 'div' || t_data[key] === 'span') {
  37. let style_data = in_data.match(/ style=['"]([^'"]*)['"]/);
  38. if(style_data) {
  39. style_data = style_data[1].replace(/position/ig, '');
  40. } else {
  41. style_data = '';
  42. }
  43. return '<' + t_data[key] + ' style="' + style_data + '">' + in_data_2 + '</' + t_data[key] + '>';
  44. } else if(t_data[key] === 'a') {
  45. let link_data = in_data.match(/ href=['"]([^'"]*)['"]/);
  46. if(link_data) {
  47. link_data = link_data[1].replace(/^javascript:/ig, '');
  48. } else {
  49. link_data = '';
  50. }
  51. return '<' + t_data[key] + ' class="opennamu_link_out" href="' + link_data + '">' + in_data_2 + '</' + t_data[key] + '>';
  52. } else if(t_data[key] === 'iframe') {
  53. let src_data = in_data.match(/ src=['"]([^'"]*)['"]/);
  54. if(src_data) {
  55. src_data = src_data[1];
  56. let src_check = src_data.match(/^http(?:s)?:\/\/([^/]+)/);
  57. if(src_check) {
  58. if(!src_list.includes(src_check[1])) {
  59. src_data = '';
  60. }
  61. } else {
  62. src_data = '';
  63. }
  64. } else {
  65. src_data = '';
  66. }
  67. let width_data = in_data.match(/ width=['"]([^'"]*)['"]/);
  68. if(width_data) {
  69. width_data = width_data[1];
  70. } else {
  71. width_data = '';
  72. }
  73. let height_data = in_data.match(/ height=['"]([^'"]*)['"]/);
  74. if(height_data) {
  75. height_data = height_data[1];
  76. } else {
  77. height_data = '';
  78. }
  79. return '<' + t_data[key] + ' src="' + src_data + '" width="' + width_data + '" height="' + height_data + '" allowfullscreen frameborder="0">' + in_data_2 + '</' + t_data[key] + '>';
  80. } else {
  81. let src_data = in_data.match(/ src=['"]([^'"]*)['"]/);
  82. if(src_data) {
  83. src_data = src_data[1];
  84. } else {
  85. src_data = '';
  86. }
  87. let width_data = in_data.match(/ width=['"]([^'"]*)['"]/);
  88. if(width_data) {
  89. width_data = width_data[1];
  90. } else {
  91. width_data = '';
  92. }
  93. let height_data = in_data.match(/ height=['"]([^'"]*)['"]/);
  94. if(height_data) {
  95. height_data = height_data[1];
  96. } else {
  97. height_data = '';
  98. }
  99. return '<' + t_data[key] + ' controls src="' + src_data + '" width="' + width_data + '" height="' + height_data + '">' + in_data_2 + '</' + t_data[key] + '>';
  100. }
  101. });
  102. }
  103. document.getElementById(name).innerHTML = data;
  104. }
  105. }
  106. function opennamu_do_footnote_spread(set_name, load_name) {
  107. if(document.getElementById(set_name + '_load').style.display === 'none') {
  108. document.getElementById(set_name).title = '';
  109. document.getElementById(set_name + '_load').innerHTML = '<a href="#' + load_name + '">(Go)</a> ' + document.getElementById(load_name + '_title').innerHTML;
  110. document.getElementById(set_name + '_load').style.display = "inline-block";
  111. } else {
  112. document.getElementById(set_name + '_load').style.display = "none";
  113. }
  114. }
  115. function opennamu_do_footnote_popover(set_name, load_name) {
  116. if(document.getElementById(set_name + '_load').style.display === 'none') {
  117. document.getElementById(set_name).title = '';
  118. document.getElementById(set_name + '_load').innerHTML = '<a href="#' + load_name + '">(Go)</a> ' + document.getElementById(load_name + '_title').innerHTML;
  119. document.getElementById(set_name + '_load').style.display = "inline-block";
  120. let width = document.getElementById(set_name + '_load').clientWidth;
  121. let screen_width = window.innerWidth;
  122. let left = document.getElementById(set_name).getBoundingClientRect().left;
  123. let left_org = document.getElementById(set_name + '_load').getBoundingClientRect().left;
  124. let top = window.pageYOffset + document.getElementById(set_name).getBoundingClientRect().top;
  125. document.getElementById(set_name + '_load').style.top = String(top) + "px";
  126. if(screen_width - (left + width) < 50) {
  127. if(left > 350) {
  128. document.getElementById(set_name + '_load').style.left = String(left - 300) + "px";
  129. } else {
  130. document.getElementById(set_name + '_load').style.left = "0px";
  131. }
  132. left = document.getElementById(set_name + '_load').getBoundingClientRect().left;
  133. width = document.getElementById(set_name + '_load').clientWidth;
  134. if(300 > width) {
  135. document.getElementById(set_name + '_load').style.left = String(left + (300 - width)) + "px";
  136. } else {
  137. document.getElementById(set_name + '_load').style.marginTop = "20px";
  138. }
  139. }
  140. } else {
  141. document.getElementById(set_name + '_load').style.display = "none";
  142. }
  143. }