index.php 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291
  1. <?PHP
  2. require_once "../pcdl/html_head.php";
  3. ?>
  4. <body>
  5. <?php
  6. require_once("../pcdl/head_bar.php");
  7. ?>
  8. <script src="../public/js/marked.js"></script>
  9. <style>
  10. body{
  11. margin: unset;
  12. }
  13. .index_toolbar{
  14. position:unset;
  15. }
  16. .search_toolbar{
  17. height: initial;
  18. padding: 0.6em 1em 0.1em 1em;
  19. background-color: var(--tool-bg-color1);
  20. border-bottom: none;
  21. }
  22. .search_fixed{
  23. position: fixed;
  24. top:-500px;
  25. width:100%;
  26. display:flex;
  27. padding: 0.5em 1em;
  28. }
  29. #dict_search_result{
  30. display:flex;
  31. }
  32. #dict_list{
  33. flex:2;
  34. text-align: right;
  35. padding-right: 1em;
  36. border-right: 1px solid var(--border-line-color);
  37. }
  38. #dict_ref{
  39. flex:6;
  40. padding:0.5em 1.5em;
  41. }
  42. #dict_user{
  43. flex:2;
  44. }
  45. .dict_word_card{
  46. border-bottom: 1px solid var(--border-line-color);
  47. padding: 5px 0;
  48. display: block;
  49. border-radius: unset;
  50. margin: 10px 0;
  51. transition: unset;
  52. box-shadow: unset;
  53. }
  54. .dict_word{
  55. border-bottom: 1px solid var(--border-line-color);
  56. padding: 5px 0;
  57. display: block;
  58. border-radius: unset;
  59. margin: 10px 0;
  60. transition: unset;
  61. box-shadow: unset;
  62. }
  63. .dict_word>.dict {
  64. font-size: 110%;
  65. color: var(--main-color);
  66. border-bottom: unset;
  67. padding-bottom:10px;
  68. }
  69. .dict_word>.mean {
  70. font-size: unset;
  71. margin: 2px 0;
  72. line-height: 150%;
  73. font-weight: unset;
  74. display: block;
  75. }
  76. /*for word split part */
  77. .dropdown_ctl{
  78. display:inline-block;
  79. margin-right: 0.7em;
  80. }
  81. .dropdown_ctl>.content{
  82. display:flex;
  83. border: 1px solid var(--border-line-color);
  84. border-radius: 99px;
  85. }
  86. .dropdown_ctl>.menu{
  87. position:absolute;
  88. box-shadow: 0 0 10px rgba(0,0,0,0.15);
  89. display:none;
  90. }
  91. .dropdown_ctl>.menu{
  92. background-color: white;
  93. }
  94. .dropdown_ctl>.content>.main_view>part{
  95. margin:0 0.5em;
  96. color:cornflowerblue;
  97. cursor: pointer;
  98. }
  99. .dropdown_ctl>.menu>.part_list {
  100. padding: 5px;
  101. cursor: pointer;
  102. }
  103. .dropdown_ctl>.menu>.part_list:hover {
  104. background-color:azure;
  105. }
  106. .dropdown_ctl>.content>.more_button {
  107. background-color: var(--btn-color);
  108. min-width: 1.4em;
  109. text-align: center;
  110. border-radius: 99px;
  111. cursor: pointer;
  112. }
  113. guide{
  114. position: relative;
  115. display:inline-block;
  116. width:1.4em;
  117. height:1.4em;
  118. cursor: pointer;
  119. background-color:gray;
  120. }
  121. guide:hover .guide_contence{
  122. display:inline-block;
  123. }
  124. .guide_contence {
  125. position: absolute;
  126. top:100%;
  127. width:18em;
  128. min-height:30em;
  129. padding:10px;
  130. background-color:white;
  131. box-shadow: 0 0 10px rgba(0,0,0,0.15);
  132. font-size:10pt;
  133. text-align:left;
  134. display:none;
  135. }
  136. .guide_contence h1{
  137. font-size:1.5em;
  138. font-weight:700;
  139. }
  140. </style>
  141. <!-- tool bar begin-->
  142. <div id='search_toolbar' class="search_toolbar">
  143. <div style="display:flex;justify-content: space-between;">
  144. <div ></div>
  145. <div>
  146. <div>
  147. <div>
  148. <guide gid="comp_split"></guide><input id="dict_ref_search_input" type="input" placeholder="<?php echo $_local->gui->search;?>" onkeyup="dict_input_keyup(event,this)" style=" margin-left: 0.5em;width: 40em;max-width: 100%;font-size:140%;padding: 0.6em;color: var(--btn-hover-bg-color);background-color: var(--btn-color);" onfocus="dict_input_onfocus()" />
  149. </div>
  150. <div id="word_parts">
  151. <div id="input_parts" style="font-size: 1.1em;padding: 2px 1em;"></div>
  152. </div>
  153. </div>
  154. <div id="pre_search_result" style="background-color: var(--btn-color);z-index: 50;">
  155. <div id="pre_search_word" class="pre_serach_block">
  156. <div id="pre_search_word_title" class="pre_serach_block_title">
  157. <div id="pre_search_word_title_left">单词</div>
  158. <div id="pre_search_word_title_right"></div>
  159. </div>
  160. <div id="pre_search_word_content" class="pre_serach_content">
  161. </div>
  162. </div>
  163. </div>
  164. </div>
  165. <button onclick="trubo_split()" style="height: fit-content;border: 1px solid var(--btn-border-color);background: var(--btn-color);border-radius: 4px;font-size: 1.2em;padding: 0.5em;">强力拆分<guide gid="comp_split"></guide></button>
  166. <div ></div>
  167. </div>
  168. <div style="display:block;z-index: 5;text-align:center;">
  169. </div>
  170. </div>
  171. <!--tool bar end -->
  172. <!-- tool bar fixed begin-->
  173. <div id='search_toolbar_1' class="search_toolbar search_fixed">
  174. <div style="display:flex;">
  175. <span >
  176. 字典
  177. </span>
  178. <div>
  179. <div>
  180. <input id="dict_ref_search_input_1" type="input" placeholder="<?php echo $_local->gui->search;?>" onkeyup="dict_input_keyup(event,this)" style="margin-left: 0.5em;width: 40em;max-width: 80%;font-size:140%;padding: 0.3em;color: var(--btn-hover-bg-color);background-color: var(--btn-color);" onfocus="dict_input_onfocus()">
  181. </div>
  182. <div id="pre_search_result_1" style="position: absolute;max-width: 100%; width: 50em;background-color: var(--btn-color);z-index: 51;display: none;">
  183. <div class="pre_serach_block">
  184. <div class="pre_serach_block_title">
  185. <div id="pre_search_word_title_left_1">单词</div>
  186. <div id="pre_search_word_title_right_1"></div>
  187. </div>
  188. <div id="pre_search_word_content_1" class="pre_serach_content">
  189. </div>
  190. </div>
  191. </div>
  192. </div>
  193. </div>
  194. <div style="display:block;z-index: 5;">
  195. </div>
  196. </div>
  197. <!--tool bar fixed end -->
  198. <script>
  199. window.addEventListener('scroll',winScroll);
  200. function winScroll(e){
  201. if(GetPageScroll().y>150){
  202. $("#search_toolbar_1").css("top",0) ;
  203. }
  204. else{
  205. $("#search_toolbar_1").css("top",GetPageScroll().y - 150) ;
  206. }
  207. }
  208. //滚动条位置
  209. function GetPageScroll()
  210. {
  211. var pos=new Object();
  212. var x, y;
  213. if(window.pageYOffset)
  214. { // all except IE
  215. y = window.pageYOffset;
  216. x = window.pageXOffset;
  217. } else if(document.documentElement && document.documentElement.scrollTop)
  218. { // IE 6 Strict
  219. y = document.documentElement.scrollTop;
  220. x = document.documentElement.scrollLeft;
  221. } else if(document.body) { // all other IE
  222. y = document.body.scrollTop;
  223. x = document.body.scrollLeft;
  224. }
  225. pos.x=x;
  226. pos.y=y;
  227. return(pos);
  228. }
  229. </script>
  230. <style>
  231. #dt_title{
  232. border-bottom: 2px solid var(--link-hover-color);
  233. }
  234. </style>
  235. <script language="javascript" src="dict.js"></script>
  236. <div id="dict_search_result" style="background-color:white;color:black;">
  237. </div>
  238. <?php
  239. if(!empty($_GET["key"])){
  240. echo "<script>";
  241. echo "dict_pre_word_click(\"{$_GET["key"]}\")";
  242. echo "</script>";
  243. }
  244. ?>
  245. <script>
  246. $("guide").each(function(){
  247. if($(this).offset().left<$(document.body).width()/2){
  248. $(this).append('<div class="guide_contence" style="left: 0;"></div>');
  249. }
  250. else{
  251. $(this).append('<div class="guide_contence" style="right: 0;"></div>');
  252. }
  253. });
  254. $("guide").mouseenter(function(){
  255. if($(this).children(".guide_contence").first().html().length>0){
  256. return;
  257. }
  258. let gid = $(this).attr("gid");
  259. let guideObj = $(this);
  260. $.get("../guide/get.php",
  261. {
  262. id:gid
  263. },
  264. function(data,status){
  265. try{
  266. let jsonGuide = JSON.parse(data);
  267. $("guide[gid='"+jsonGuide.id+"']").find(".guide_contence").html(marked(jsonGuide.data));
  268. }
  269. catch(e){
  270. console.error(e);
  271. }
  272. });
  273. });
  274. </script>
  275. <?php
  276. include "../pcdl/html_foot.php";
  277. ?>