editor.php 43 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312
  1. <?php
  2. require_once 'checklogin.inc';
  3. require_once '../public/config.php';
  4. require_once '../public/load_lang.php';
  5. //load language file
  6. if(file_exists($dir_language.$currLanguage.".php")){
  7. require $dir_language.$currLanguage.".php";
  8. }
  9. else{
  10. include $dir_language."default.php";
  11. }
  12. if(isset($_GET["device"])){$currDevice=$_GET["device"];}
  13. else{$currDevice="computer";}
  14. //require "module/editor/language/$currLanguage.php";
  15. ?>
  16. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
  17. <html>
  18. <head>
  19. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
  20. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  21. <title id="file_title"><?php echo $_local->gui->pcd_studio; ?></title>
  22. <link rel="shortcut icon" href="../favicon.icon" />
  23. <link type="text/css" rel="stylesheet" href="css/style.css"/>
  24. <link type="text/css" rel="stylesheet" href="css/color_day.css" id="colorchange" />
  25. <link type="text/css" rel="stylesheet" href="css/style_mobile.css" media="screen and (max-width:800px)">
  26. <link href="https://fonts.googleapis.com/css2?family=Padauk:wght@400;700&display=swap" rel="stylesheet">
  27. <link type="text/css" rel="stylesheet" href="../public/css/notify.css"/>
  28. <?php
  29. if(file_exists($dir_user_base.$userid.$dir_myApp."/style.css")){
  30. echo "<link type=\"text/css\" rel=\"stylesheet\" href=\"".$dir_user_base.$userid.$dir_myApp."/style.css\"/>";
  31. }
  32. ?>
  33. <script src="../guide/guide.js"></script>
  34. <link type="text/css" rel="stylesheet" href="../guide/guide.css"/>
  35. <script src="../public/js/marked.js"></script>
  36. <script src="../public/js/jquery-3.6.js"></script>
  37. <script src="../public/js/jquery-ui-1.12.1/jquery-ui.js"></script>
  38. <script language="javascript" src="config.js"></script>
  39. <script language="javascript" src="../pali_sent/pali_sent_list.js"></script>
  40. <script language="javascript" src="../usent/usent_ref.js"></script>
  41. <script language="javascript" src="js/data.js"></script>
  42. <script language="javascript" src="js/common.js"></script>
  43. <script language="javascript" src="js/render.js"></script>
  44. <script language="javascript" src="js/xml.js"></script>
  45. <script language="javascript" src="js/editor.js"></script>
  46. <script language="javascript" src="js/wbw_dict.js"></script>
  47. <script language="javascript" src="js/wizard.js"></script>
  48. <script language="javascript" src="js/wordmap.js"></script>
  49. <script language="javascript" src="js/dict.js"></script>
  50. <script language="javascript" src="js/relation.js"></script>
  51. <script language="javascript" src="js/relation_list.js"></script>
  52. <script language="javascript" src="sent/sent.js"></script>
  53. <script language="javascript" src="../public/js/notify.js"></script>
  54. <script language="javascript" src="../widget/notify.js"></script>
  55. <link type="text/css" rel="stylesheet" href="../widget/notify.css"/>
  56. <script language="javascript" src="../public/js/comm.js"></script>
  57. <script language="javascript" src="../public/js/localforage.min.js"></script>
  58. <script language="javascript" src="../public/script/my.js"></script>
  59. <script src="../../node_modules/mermaid/dist/mermaid.min.js"></script>
  60. <script language="javascript" src="module/editor/language/default.js"></script>
  61. <script src="../term/term.js"></script>
  62. <script src="../term/note.js"></script>
  63. <script src="../term/term_popup.js"></script>
  64. <link type="text/css" rel="stylesheet" href="../term/term.css"/>
  65. <script src="./js/message.js"></script>
  66. <script src="../uwbw/update.js"></script>
  67. <script src="../usent/usent.js"></script>
  68. <script src="../ucenter/setting.js"></script>
  69. <script src="../fileindex/file_info.js"></script>
  70. <script src="../channal/channal.js"></script>
  71. <script>
  72. get_channel_list_callback=renderChannelList();
  73. </script>
  74. <script language="javascript">
  75. <?php
  76. //加载js语言包
  77. //require_once '../public/load_lang_js.php';
  78. ?>
  79. <?php
  80. //加载js语言包
  81. if(file_exists(_DIR_LANGUAGE_."/".$currLanguage.".json")){
  82. echo "var gLocal = ".file_get_contents(_DIR_LANGUAGE_."/".$currLanguage.".json").";";
  83. }
  84. else{
  85. echo "var gLocal = ".file_get_contents(_DIR_LANGUAGE_."/default.json").";";
  86. }
  87. ?>
  88. var gDownloadListString="";
  89. var g_device="computer";
  90. var strSertch = location.search;
  91. var gConfigDirMydocument="<?php echo _DIR_USER_DOC_."/".$userid._DIR_MYDOCUMENT_; ?>/";
  92. if(strSertch.length>0){
  93. strSertch = strSertch.substr(1);
  94. var sertchList=strSertch.split('&');
  95. for (x in sertchList){
  96. var item = sertchList[x].split('=');
  97. if(item[0]=="device"){
  98. g_device=item[1];
  99. }
  100. }
  101. }
  102. if(g_device=="mobile"){
  103. g_is_mobile=true;
  104. }
  105. else{
  106. g_is_mobile=false;
  107. }
  108. var gCaseTable=<?php echo file_get_contents("../public/js/case.json"); ?>
  109. </script>
  110. </head>
  111. <body class="mainbody" id="mbody" onLoad="editor_windowsInit()">
  112. <style>
  113. .term_link:hover .guide_contence {
  114. display: inline-block;
  115. }
  116. .trans_text_block{
  117. border-left: 5px solid #ccd1ff;
  118. border-color: #ccd1ff;
  119. background-color:unset;
  120. margin-bottom: 0.5em;
  121. padding: 0.5em 0.5em 0.1em 0.5em;
  122. padding-top:0;
  123. }
  124. .translate_sent_head{
  125. height: 17em;
  126. overflow-y: scroll;
  127. }
  128. .translate_sent_head_content .readonly{
  129. border-color: #d1d1d1;
  130. background-color: #f1f1f1;
  131. }
  132. .trans_text_content{
  133. color: unset;
  134. }
  135. .trans_text_content p{
  136. margin-block-start: 0.3em;
  137. margin-block-end: 0;
  138. }
  139. .trans_text_info{
  140. font-size: 80%;
  141. border-top: 1px solid gray;
  142. padding-top: 5px;
  143. color: var(--detail-color);
  144. display:flex;
  145. justify-content: space-between;
  146. border:none;
  147. }
  148. .trans_text_info .tag{
  149. font-size: 75%;
  150. }
  151. .trans_text_info .tools{
  152. /*visibility: hidden;*/
  153. }
  154. .trans_text_block:hover .trans_text_info .tools{
  155. visibility: visible;
  156. }
  157. wnh{
  158. background-color: var(--link-hover-color);
  159. color: var(--btn-color);
  160. border-radius: 0.8em;
  161. cursor: pointer;
  162. padding: 2px;
  163. font-size: 80%;
  164. display: inline-block;
  165. min-width: 1.2em;
  166. width: fit-content;
  167. height: 1.2em;
  168. line-height: 1.2em;
  169. text-align: center;
  170. }
  171. #left_tool_bar {
  172. position: fixed;
  173. top: 0;
  174. left: 0;
  175. background-color: var(--tool-bg-color);
  176. color: var(--tool-color);
  177. height: 100%;
  178. width: 2.5em;
  179. font-size: 100%;
  180. z-index: 16;
  181. display: -webkit-flex;
  182. display: -moz-flex;
  183. display: flex;
  184. flex-direction: column;
  185. -webkit-align-items: center;
  186. -moz-align-items: center;
  187. align-items: center;
  188. -webkit-justify-content: space-between;
  189. -moz-justify-content: space-between;
  190. justify-content: space-between;
  191. padding: 4em 4px 1em 4px;
  192. border-right: 1px solid var(--tool-bg-color3);
  193. }
  194. #left_tool_bar::-webkit-scrollbar {
  195. display: none;
  196. }
  197. .border_top{
  198. border-top: 1px solid var(--tool-line-color);
  199. width: 1.5em;
  200. margin: 10px 5px 10px 5px;
  201. display: inline-block;
  202. }
  203. .left_panal_caption{
  204. border-bottom: 1px solid var(--tool-bg-color3);
  205. padding: 8px 0 8px 3.2em;
  206. font-weight: 700;
  207. }
  208. .left_panal_content{
  209. padding: 8px 0 8px 3.2em;
  210. }
  211. #svg_parent2{
  212. width: 1em;
  213. margin-left: -1em;
  214. }
  215. guide {
  216. margin: 0 15px 0 -8px;
  217. }
  218. .translate_sent_head_toolbar {
  219. display: none;
  220. }
  221. div#input_org_select{
  222. position: relative;
  223. }
  224. div#input_org_select .case_dropbtn {
  225. padding: 0 6px;
  226. border-radius: 4px;
  227. min-width: 1em;
  228. min-height: 1.3em;
  229. background: url(../../node_modules/bootstrap-icons/icons/chevron-double-down.svg);
  230. background-repeat: no-repeat;
  231. background-position-x: center;
  232. background-position-y: bottom;
  233. background-origin: content-box;
  234. background-color: var(--main-color1);
  235. white-space: nowrap;
  236. }
  237. #parent_grammar{
  238. padding: 0 6px;
  239. border-radius: 4px;
  240. min-width: 1em;
  241. min-height: 1.3em;
  242. background: url(../../node_modules/bootstrap-icons/icons/chevron-double-down.svg);
  243. background-repeat: no-repeat;
  244. background-position-x: center;
  245. background-position-y: bottom;
  246. background-origin: content-box;
  247. background-color: var(--main-color1);
  248. white-space: nowrap;
  249. }
  250. #word_mdf_parts_dropdown a {
  251. width: 100%;
  252. display: inline-block;
  253. overflow: hidden;
  254. white-space: nowrap;
  255. text-overflow: ellipsis;
  256. }
  257. #merge_button{
  258. position: absolute;
  259. left: 7em;
  260. border: unset;
  261. height: 6em;
  262. width: 3em;
  263. padding: unset;
  264. transform: scaleX(0.6);
  265. }
  266. #merge_button>.icon{
  267. fill: var(--link-color);
  268. }
  269. #merge_button:hover{
  270. background: unset;
  271. }
  272. #merge_button:hover>.icon{
  273. fill: var(--link-hover-color);
  274. }
  275. #om_dropdown_area::-webkit-scrollbar {
  276. width: 10px;
  277. height: 10px;
  278. }
  279. #om_dropdown_area::-webkit-scrollbar-thumb {
  280. background-color: var(--link-color);
  281. }
  282. #om_dropdown_area::-webkit-scrollbar-thumb:hover {
  283. background-color:var(--tool-link-hover-color);
  284. }
  285. #om_dropdown_area::-webkit-scrollbar-button:single-button {
  286. width: 10px
  287. height: 10px;
  288. display: block;
  289. background-color: var(--link-color);
  290. border-radius: 10px;
  291. }
  292. #om_dropdown_area::-webkit-scrollbar-button:single-button:hover {
  293. background-color:var(--tool-link-hover-color);
  294. }
  295. </style>
  296. <link type="text/css" rel="stylesheet" href="css/print.css" media="print" />
  297. <style id="display_set">
  298. </style>
  299. <!--左侧工具栏-->
  300. <div id="left_tool_bar">
  301. <div>
  302. <?php
  303. $plugin_list = json_decode(file_get_contents("plugin/index.json"));
  304. foreach($plugin_list as $info){
  305. if($info->attach=="left_top" && $info->enable=="true"){
  306. echo "<button id=\"left_toc\" type=\"button\" class=\"icon_btn\" onclick=\"setNaviVisibility('{$info->id}')\" title=\"";
  307. if(substr($info->tooltip,0,1)=="#"){
  308. $realTipText = substr($info->tooltip,1);
  309. if(isset($_local_arr[$realTipText])){
  310. echo $_local_arr[$realTipText];
  311. }
  312. else{
  313. echo $realTipText;
  314. }
  315. }
  316. else{
  317. echo $info->tooltip;
  318. }
  319. echo "\">";
  320. echo "<svg class=\"icon\">";
  321. $iconFile = "plugin/".$info->dir."/".$info->icon;
  322. echo "<use xlink:href=\"{$iconFile}\"></use>";
  323. echo "</svg>";
  324. echo "<span class='icon_notify' id='icon_notify_{$info->id}'></span>";
  325. echo "</button>";
  326. }
  327. }
  328. ?>
  329. </div>
  330. <div>
  331. <div>
  332. <?php
  333. foreach($plugin_list as $info){
  334. if($info->attach=="left_mid" && $info->enable=="true"){
  335. echo "<button id=\"left_toc\" type=\"button\" class=\"icon_btn\" onclick=\"setNaviVisibility('{$info->id}')\" title=\"";
  336. if(substr($info->tooltip,0,1)=="#"){
  337. $realTipText = substr($info->tooltip,1);
  338. if(isset($_local_arr[$realTipText])){
  339. echo $_local_arr[$realTipText];
  340. }
  341. else{
  342. echo $realTipText;
  343. }
  344. }
  345. else{
  346. echo $info->tooltip;
  347. }
  348. echo "\">";
  349. echo "<svg class=\"icon\">";
  350. $iconFile = "plugin/".$info->dir."/".$info->icon;
  351. echo "<use xlink:href=\"{$iconFile}\"></use>";
  352. echo "</svg>";
  353. echo "<span class='icon_notify' id='icon_notify_{$info->id}'></span>";
  354. echo "</button>";
  355. }
  356. }
  357. ?>
  358. </div>
  359. <span class="border_top"></span>
  360. <div>
  361. <?php
  362. foreach($plugin_list as $info){
  363. if($info->attach=="left_bottom" && $info->enable=="true"){
  364. echo "<button id=\"left_toc\" type=\"button\" class=\"icon_btn\" onclick=\"setNaviVisibility('{$info->id}')\" title=\"";
  365. if(substr($info->tooltip,0,1)=="#"){
  366. $realTipText = substr($info->tooltip,1);
  367. if(isset($_local_arr[$realTipText])){
  368. echo $_local_arr[$realTipText];
  369. }
  370. else{
  371. echo $realTipText;
  372. }
  373. }
  374. else{
  375. echo $info->tooltip;
  376. }
  377. echo "\">";
  378. echo "<svg class=\"icon\">";
  379. $iconFile = "plugin/".$info->dir."/".$info->icon;
  380. echo "<use xlink:href=\"{$iconFile}\"></use>";
  381. echo "</svg>";
  382. echo "<span class='icon_notify' id='icon_notify_{$info->id}'></span>";
  383. echo "</button>";
  384. }
  385. }
  386. ?>
  387. </div>
  388. </div>
  389. </div>
  390. <!--关闭打印模式 -->
  391. <div id="btn_close_printprev">
  392. <a href="#" onclick="printpreview(false)">&nbsp;&nbsp; </a>
  393. </div>
  394. <!--顶部工具栏tool bar begin-->
  395. <div id='toolbar'>
  396. <!--左侧的区块-->
  397. <div style="display: inline-flex;flex: 4;max-width:40vw">
  398. <svg class="icon" style="height: 2.7em; width: 12em;">
  399. <use xlink:href="../public/images/svg/wikipali_banner.svg#wikipali_banner"></use>
  400. </svg>
  401. <span style="height: fit-content;margin: auto 0;">
  402. <span id="net_up" style="display:none;"></span>
  403. <span id="msg_tool_bar"><svg class='icon'><use xlink:href='../studio/svg/icon.svg#pause_ms'></use></svg></span>
  404. <span id="net_down" style="display:none;"></span>
  405. </span>
  406. <span id="editor_doc_title" style="margin: auto 0;max-width: 20em;height: fit-content;position: inherit;"></span>
  407. </div>
  408. <!--工具栏中间的区块-->
  409. <div style="flex: 2;display: flex;justify-content: center;">
  410. <!--手机版显示工具栏按钮-->
  411. <span class="dropdown toolbtn" onmouseover="switchMenu(this,'topTools')">
  412. <div>
  413. <button class="icon_btn" onClick="switchMenu(this,'topTools')" id="tools_view">
  414. <svg class="icon">
  415. <use xlink:href="svg/icon.svg#ic_toc"></use>
  416. </svg>
  417. </button>
  418. </div>
  419. </span>
  420. <div class="toolgroup1" id="topTools">
  421. <?php
  422. #头部中间的插件
  423. foreach($plugin_list as $info){
  424. if($info->attach=="top_mid" && $info->enable=="true"){
  425. echo "<style>";
  426. include "plugin/{$info->dir}/style.css";
  427. echo "</style>";
  428. echo "<script src=\"plugin/{$info->dir}/module_function.js\"></script>";
  429. echo "<div class='dropdown' onmouseover=\"switchMenu(this,'".$info->id."')\" onmouseout=\"hideMenu()\">";
  430. echo "<button class=\"dropbtn icon_btn\">";
  431. echo "<svg class=\"icon\">";
  432. $iconFile = "plugin/".$info->dir."/".$info->icon;
  433. echo "<use xlink:href=\"{$iconFile}\"></use>";
  434. echo "</svg>";
  435. echo "<span class='icon_notify' id='icon_notify_{$info->id}'></span>";
  436. echo "</button>";
  437. echo "<div class=\"dropdown-content\" id=\"".$info->id."\" style=\"width:auto\">";
  438. require "plugin/{$info->dir}/gui.html";
  439. echo "</div>";
  440. echo "</div>";
  441. }
  442. }
  443. ?>
  444. <!--显示模式-->
  445. <div class="dropdown" onmouseover="switchMenu(this,'menuUseMode')" onmouseout="hideMenu()" style="display:none;">
  446. <div style="">
  447. <button class="dropbtn icon_btn" onClick="switchMenu(this,'menuUseMode')" id="use_mode">
  448. <svg class="icon">
  449. <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="svg/icon.svg#ic_reader_mode"></use>
  450. </svg>
  451. </button>
  452. </div>
  453. <div class="dropdown-content black_background" id="menuUseMode">
  454. <a href="#" onclick="setUseMode('Edit')">
  455. <svg class="icon">
  456. <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="svg/icon.svg#ic_mode_edit"></use>
  457. </svg>
  458. 编辑模式
  459. </a>
  460. <a href="#" onclick="setUseMode('note')">
  461. <svg class="icon">
  462. <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="svg/icon.svg#ic_reader_mode"></use>
  463. </svg>
  464. 笔记模式
  465. </a>
  466. <a href="#" onclick="setUseMode('Read')">
  467. <svg class="icon">
  468. <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="svg/icon.svg#ic_reader_mode"></use>
  469. </svg>
  470. 阅读模式
  471. </a>
  472. </div>
  473. </div>
  474. <!--infomation panal-->
  475. <button id="info_panal" class="icon_btn" type="button" onclick="setInfoPanalVisibility()" title="<?php echo $_local->gui->info_panal;?>" style="display:none;">
  476. <svg class="icon">
  477. <use xlink:href="svg/icon.svg#ic_info_outline"></use>
  478. </svg>
  479. </button>
  480. <!--apply all-->
  481. <button id="B_ApplyAuto" class="icon_btn" onclick="applyAllSysMatch()" type="button" title="apply all" style="display:none;">
  482. <svg class="icon">
  483. <use xlink:href="svg/icon.svg#ic_done_all"></use>
  484. </svg>
  485. </button>
  486. <!--Save-->
  487. <button id="B_Save" class="icon_btn" onclick="editor_save()" type="button" style="display:none;" title="<?php echo $_local->gui->save;?>">
  488. <svg class="icon">
  489. <use xlink:href="svg/icon.svg#ic_save"></use>
  490. </svg>
  491. </button>
  492. </div>
  493. </div>
  494. <!--工具栏右侧的区块开始-->
  495. <div class="tab_a1" style="flex: 4;display: flex;justify-content: flex-end;">
  496. <?php
  497. foreach($plugin_list as $info){
  498. if($info->attach=="top_right" && $info->enable=="true"){
  499. echo "<button id=\"tab_rb_{$info->id}\" type=\"button\" class=\"icon_btn\" onclick=\"tab_click_b('{$info->id}','tab_rb_{$info->id}',right_panal_slide_toggle,'tab_rb_{$info->id}')\" title=\"";
  500. if(substr($info->tooltip,0,1)=="#"){
  501. $realTipText = substr($info->tooltip,1);
  502. if(isset($_local_arr[$realTipText])){
  503. echo $_local_arr[$realTipText];
  504. }
  505. else{
  506. echo $realTipText;
  507. }
  508. }
  509. else{
  510. echo $info->tooltip;
  511. }
  512. echo "\">";
  513. echo "<svg class=\"icon\">";
  514. $iconFile = "plugin/".$info->dir."/".$info->icon;
  515. echo "<use xlink:href=\"{$iconFile}\"></use>";
  516. echo "</svg>";
  517. echo "<span class='icon_notify' id='icon_notify_{$info->id}'></span>";
  518. echo "<span class='icon_notify' id='icon_notify_{$info->id}'></span>";
  519. echo "</button>";
  520. }
  521. }
  522. ?>
  523. </div>
  524. </div>
  525. <!--顶部工具栏结束-->
  526. <!--文档载入进度条-->
  527. <div id="load_progress_div">
  528. <svg id="circleProcess" xmlns="http://www.w3.org/2000/svg">
  529. <circle id="circle" cx="50%" cy="50%" r="32%" ></circle>
  530. </svg>
  531. </div>
  532. <span id="load_progress_num" ></span>
  533. <!--tool bar end -->
  534. <!--loading -->
  535. <svg viewBox="0 0 1000 4" id="loading_bar" xmlns="http://www.w3.org/2000/svg">
  536. <line x1="0" y1="2" x2="1000" y2="2" id="loading" stroke-width="5px" stroke-linecap="round"/>
  537. </svg>
  538. <!--tool bar end -->
  539. <!--文档载入进度条结束-->
  540. <style id="mycss">
  541. </style>
  542. <div class="main">
  543. <!-- leftmenu begin-->
  544. <div id="leftmenuinner" class="viewswitch_off" style="z-index:13;">
  545. <div id="menubartoolbar" style="display: none">
  546. <select id="id_editor_menu_select" name="menu" onchange="menuSelected(this)">
  547. <option value="menu_toc" selected><?php echo $_local->gui->content;?></option>
  548. <option value="menu_pali_cannon"><?php echo $_local->gui->pali_canon;?></option>
  549. <option value="menu_bookmark"><?php echo $_local->gui->mark;?></option>
  550. <option value="menu_project"><?php echo $_local->gui->project;?></option>
  551. <option value="menu_dict"><?php echo $_local->gui->dict;?></option>
  552. <option value="menu_layout"><?php echo $_local->gui->layout;?></option>
  553. <option value="menu_plugin"><?php echo $_local->gui->plugin;?></option>
  554. </select>
  555. </div>
  556. <div id="menubartoolbar_New" style="display:none;">
  557. <ul class="common-tab">
  558. <li id="menu_toc_li" class="common-tab_li_act" onclick="menuSelected_2(menu_toc,'menu_toc_li','menu' )"><?php echo $_local->gui->content;?></li>
  559. <li id="menu_bookmark_li" class="common-tab_li" onclick="menuSelected_2(menu_bookmark,'menu_bookmark_li','menu' )"><?php echo $_local->gui->mark;?></li>
  560. <li id="menu_project_li" class="common-tab_li" onclick="menuSelected_2(menu_project,'menu_project_li','menu' )"><?php echo $_local->gui->project;?></li>
  561. <li id="menu_dict_li" class="common-tab_li" onclick="menuSelected_2(menu_dict,'menu_dict_li','menu' )"><?php echo $_local->gui->dict;?></li>
  562. <li id="menu_layout_li" class="common-tab_li" onclick="menuSelected_2(menu_layout,'menu_layout_li','menu' )"><?php echo $_local->gui->layout;?></li>
  563. <li id="menu_plugin_li" class="common-tab_li" onclick="menuSelected_2(menu_plugin,'menu_plugin_li','menu' )"><?php echo $_local->gui->plugin;?></li>
  564. </ul>
  565. </div>
  566. <div class='toc' id='leftmenuinnerinner'>
  567. <!-- toc begin -->
  568. <?php
  569. foreach($plugin_list as $info){
  570. if(($info->attach=="left_top" || $info->attach=="left_mid" ||$info->attach=="left_bottom") && $info->enable=="true"){
  571. echo "<div id=\"{$info->id}\">";
  572. echo "<style>";
  573. include "plugin/{$info->dir}/style.css";
  574. echo "</style>";
  575. echo "<script src=\"plugin/{$info->dir}/module_function.js\"></script>";
  576. echo "<div class=\"left_panal_caption\">";
  577. echo $info->caption;
  578. echo "</div>";
  579. echo "<div class=\"left_panal_content\">";
  580. require "plugin/{$info->dir}/gui.html";
  581. echo "</div>";
  582. echo "</div>";
  583. }
  584. }
  585. ?>
  586. <!-- dictionary begin -->
  587. <style>
  588. <?php include 'module/editor_dictionary/style.css';?>
  589. </style>
  590. <?php
  591. //require 'module/editor_dictionary/language/default.php';
  592. //require "module/editor_dictionary/language/$currLanguage.php";
  593. require 'module/editor_dictionary/gui.html';
  594. ?>
  595. <!-- dictionary end -->
  596. <style>
  597. <?php include 'module/editor_palicannon/style.css';?>
  598. </style>
  599. <?php
  600. //require 'module/editor_palicannon/language/default.php';
  601. //require "module/editor_palicannon/language/$currLanguage.php";
  602. //require 'module/editor_palicannon/gui.html';
  603. ?>
  604. </div>
  605. </div>
  606. <!-- leftmenu end -->
  607. <!-- leftmenu background begin-->
  608. <div id='BV' class='blackscreen' onClick='setNaviVisibility()' style="z-index:10;"></div>
  609. <!--main edit begin-->
  610. <div class='mainview' id='body_mainview'>
  611. <!-- 逐词解析与译文编辑区 -->
  612. <div id="sutta_text">
  613. <div class="sutta_top_blank"></div>
  614. </div>
  615. <!-- infomation panal -->
  616. <div id="id_info_panal">
  617. <select id="id_info_window_select" name="menu" onchange="windowsSelected(this)">
  618. <option value="view_vocabulary"><?php echo $_local->gui->vocabulary;?></option>
  619. <option value="view_dict_all"><?php echo $_local->gui->inline_dictionary;?></option>
  620. <option value="view_dict_curr"><?php echo $_local->gui->my_dictionary;?></option>
  621. <option value="view_debug"><?php echo $_local->gui->debug;?></option>
  622. </select>
  623. <button type="button" onclick="setInfoPanalSize('hidden')"><?php echo $_local->gui->hidden;?></button>
  624. <button type="button" onclick="setInfoPanalSize('min')"><?php echo $_local->gui->min;?></button>
  625. <button type="button" onclick="setInfoPanalSize('half')"><?php echo $_local->gui->half;?></button>
  626. <button type="button" onclick="setInfoPanalSize('max')"><?php echo $_local->gui->max;?></button>
  627. <div id='id_info_panal_inner'>
  628. <div id="word_table">
  629. <p><br/><?php echo $_local->gui->word_list;?><input id="button_wordlist_refresh" onclick="refreshWordList()" type="button" value="<?php echo $_local->gui->refresh;?>" /> </p>
  630. <div id="word_table_inner"></div>
  631. </div>
  632. <div id="id_dict_match_result">
  633. <p><br/><?php echo $_local->gui->dictionary_match_result;?></p>
  634. <div id="id_dict_match_result_inner"></div>
  635. </div>
  636. <div id="id_dict_curr_word">
  637. <div id="id_dict_curr_word_inner"></div>
  638. </div>
  639. <div class="debugMsg" id="id_debug"><!--调试信息-->
  640. <div id="id_debug_output"></div>
  641. </div>
  642. </div>
  643. </div>
  644. <!-- infomation panal end -->
  645. </div>
  646. <!-- end-->
  647. <!--class="main"-->
  648. <div class="debug_info"><span id="debug"></span></div>
  649. <!--逐词解析编辑窗口-->
  650. <div id="modifyDiv">
  651. <div id="modifywin" style="">
  652. <div>
  653. <ul id="id_select_modyfy_type" class="common-tab">
  654. <li id="detail_li" class="common-tab_li_act" onclick="select_modyfy_type('modify_detaile','detail_li')"><?php echo $_local->gui->detaile;?></li>
  655. <li id="mark_li" class="common-tab_li" onclick="select_modyfy_type('modify_bookmark','mark_li')"><?php echo $_local->gui->mark;?></li>
  656. <li id="note_li" class="common-tab_li" onclick="select_modyfy_type('modify_note','note_li')"><?php echo $_local->gui->note;?></li>
  657. <li id="spell_li" class="common-tab_li" onclick="select_modyfy_type('modify_spell','spell_li')"><?php echo "高级";//.$_local->gui->source?></li>
  658. </ul>
  659. </div>
  660. <div id="modify_detaile">
  661. <!-- 意思 -->
  662. <div class="edit_detail_p">
  663. <guide gid="studio_general_meaning">⑤</guide>
  664. <span class="edit_detail_span"><?php echo $_local->gui->meaning;?>:</span>
  665. <!--<button id="merge_button" onclick="copy_part_mean_to_mean()">
  666. <svg class="icon" style="transform: rotate(315deg);height: 4em;width: 6em;">
  667. <use xlink="http://www.w3.org/1999/xlink" href="../../node_modules/bootstrap-icons/bootstrap-icons.svg#arrow-90deg-right">
  668. </svg>
  669. </button>-->
  670. <input type="text" id="input_meaning" class="input_bar" value="" name="in_meaning">
  671. <div class="case_dropdown">
  672. <svg class="edit_icon">
  673. <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="svg/icon.svg#ic_more"></use>
  674. </svg>
  675. <div id="word_mdf_mean_dropdown" class="case_dropdown-content">
  676. </div>
  677. </div>
  678. </div>
  679. <!-- 拆分 -->
  680. <div class="edit_detail_p">
  681. <guide gid="studio_break_down">②</guide>
  682. <span class="edit_detail_span"><?php echo $_local->gui->part;?>:</span>
  683. <input type="text" id="input_org" class="input_bar" value="" name="in_org" onkeydown="match_key(this)" onkeyup="unicode_key(this) " onchange="input_org_change()">
  684. <div class="case_dropdown">
  685. <svg class="edit_icon">
  686. <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="svg/icon.svg#ic_more"></use>
  687. </svg>
  688. <div id="word_mdf_parts_dropdown" class="case_dropdown-content">
  689. </div>
  690. </div>
  691. </div>
  692. <!-- 拆分意思 -->
  693. <div class="edit_detail_p" >
  694. <guide gid="studio_part_meaning">④</guide>
  695. <span class="edit_detail_span"><?php echo $_local->gui->partmeaning;?>:</span>
  696. <div id="input_org_select" class="input_bar" style="width:80%; display:inline-flex;justify-content: space-between;"></div>
  697. <input type="text" id="input_om" class="input_bar" value="" name="in_om" onchange='input_om_change(this)' onblur="input_org_switch('input_om','input_org_select')">
  698. </div>
  699. <!-- 格位 -->
  700. <div class="edit_detail_p">
  701. <guide gid="grammar_abbr">③</guide>
  702. <span class="edit_detail_span"><?php echo $_local->gui->gramma;?>:</span>
  703. <p><input type="text" id="input_case" value="" name="in_case" onblur="input_org_switch('input_case','input_select_case')" ></p>
  704. <div id="input_select_case" class="input_bar" style="width:80%; display:inline-flex;">
  705. <div style="display:inline-flex;">
  706. <span></span>
  707. <span></span>
  708. <span></span>
  709. <span></span>
  710. </div>
  711. <button style="margin-left:auto; display:none;" onclick="input_org_switch('input_select_case','input_case')">
  712. <?php echo $_local->gui->source;?>
  713. </button>
  714. </div>
  715. <div class="case_dropdown">
  716. <svg class="edit_icon">
  717. <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="svg/icon.svg#ic_more"></use>
  718. </svg>
  719. <!--下拉菜单-->
  720. <div id="word_mdf_case_dropdown" class="case_dropdown-content">
  721. </div>
  722. </div>
  723. </div>
  724. <!-- 语基 -->
  725. <div class="edit_detail_p">
  726. <guide gid="studio_parent">①</guide>
  727. <script>
  728. </script>
  729. <span class="thin_icon_btn" onclick="edit_show_prt_prt(this)">
  730. <svg id="svg_parent2" class="icon">
  731. <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="svg/icon.svg#ic_chevron_right_24px"></use>
  732. </svg>
  733. </span>
  734. <span class="edit_detail_span"><?php echo $_local->gui->parent;?>:</span>
  735. <input type="text" id="id_text_parent" class="input_bar" onkeydown="match_key(this)" onkeyup="unicode_key(this)" />
  736. <div class="case_dropdown">
  737. <svg class="edit_icon">
  738. <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="svg/icon.svg#ic_more"></use>
  739. </svg>
  740. <div id="word_mdf_parent_dropdown" class="case_dropdown-content">
  741. </div>
  742. </div>
  743. </div>
  744. <!-- 词源 -->
  745. <div id="edit_detail_prt_prt" class="edit_detail_p" style="display:none;">
  746. <span style="display:flex;">
  747. <guide gid="studio_parent2">衍生原型</guide>
  748. <div class="case_dropdown" style="padding-left: 0.5em;width: 6em;display: flex;">
  749. <span style="padding-right: 4px;"></span>
  750. <span id="parent_grammar" style="display: inline-block;min-width: 2em;border-radius: 4px;padding: 0 4px;background-color: #8484843d;"></span>
  751. <input type="hidden" id="input_parent_grammar" />
  752. <div id="word_mdf_prt_prt_grammar_dropdown" style="margin-top: 22px;" class="case_dropdown-content">
  753. <a onclick="edit_parent_grammar_changed('')"><?php echo $_local->gui->empty; ?></a>
  754. <a onclick="edit_parent_grammar_changed('.pp.')"><?php echo $_local->gui->pp; ?></a>
  755. <a onclick="edit_parent_grammar_changed('.prp.')"><?php echo $_local->gui->prp; ?></a>
  756. <a onclick="edit_parent_grammar_changed('.fpp.')"><?php echo $_local->gui->fpp; ?></a>
  757. <a onclick="edit_parent_grammar_changed('.caus.')"><?php echo $_local->gui->caus; ?></a>
  758. <a onclick="edit_parent_grammar_changed('.pass.')"><?php echo $_local->gui->pass; ?></a>
  759. </div>
  760. </div>
  761. <input type="text" id="id_text_prt_prt" class="input_bar" onkeydown="match_key(this)" onkeyup="unicode_key(this)" />
  762. <div class="case_dropdown">
  763. <svg class="edit_icon">
  764. <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="svg/icon.svg#ic_more"></use>
  765. </svg>
  766. <div id="word_mdf_prt_prt_dropdown" class="case_dropdown-content">
  767. </div>
  768. </div>
  769. </span>
  770. <div>
  771. <?php echo $_local->gui->relation; ?>
  772. <imput type="hidden" id="id_relation_text" value="" />
  773. <button onclick="rela_add_word()">➕</button>
  774. <div id="relation_div">
  775. </div>
  776. </div>
  777. </div>
  778. </div>
  779. <div id="modify_bookmark">
  780. <ul id="id_book_mark_color_select" class="bookmark-tab">
  781. <li id="id_bmc0" class="bookmarkcolorblock bookmarkcolor0" onclick="setBookMarkColor(this,'bmc0')">
  782. <svg class="icon">
  783. <use xlink:href="svg/icon.svg#ic_clear">×</use>
  784. </svg>
  785. </li>
  786. <li id="id_bmc1" class="bookmarkcolorblock bookmarkcolor1" onclick="setBookMarkColor(this,'bmc1')">
  787. <svg class="icon">
  788. <use xlink:href="svg/icon.svg#ic_bookmark_on">1</use>
  789. </svg>
  790. </li>
  791. <li id="id_bmc2" class="bookmarkcolorblock bookmarkcolor2" onclick="setBookMarkColor(this,'bmc2')">
  792. <svg class="icon">
  793. <use xlink:href="svg/icon.svg#ic_bookmark_on">2</use>
  794. </svg>
  795. </li>
  796. <li id="id_bmc3" class="bookmarkcolorblock bookmarkcolor3" onclick="setBookMarkColor(this,'bmc3')">
  797. <svg class="icon">
  798. <use xlink:href="svg/icon.svg#ic_bookmark_on">3</use>
  799. </svg>
  800. </li>
  801. <li id="id_bmc4" class="bookmarkcolorblock bookmarkcolor4" onclick="setBookMarkColor(this,'bmc4')">
  802. <svg class="icon">
  803. <use xlink:href="svg/icon.svg#ic_bookmark_on">4</use>
  804. </svg>
  805. </li>
  806. <li id="id_bmc5" class="bookmarkcolorblock bookmarkcolor5" onclick="setBookMarkColor(this,'bmc5')">
  807. <svg class="icon">
  808. <use xlink:href="svg/icon.svg#ic_bookmark_on">5</use>
  809. </svg>
  810. </li>
  811. <li id="id_bmca" class="bookmarkcolorblock bookmarkcolora" onclick="setBookMarkColor(this,'bmca')">
  812. <svg class="icon">
  813. <use xlink:href="svg/icon.svg#ic_bookmark_on">A</use>
  814. </svg>
  815. </li>
  816. </ul>
  817. <textarea id="id_text_bookmark" rows="6" col="28" style="margin-left: 3px; margin-right: 3px; width: 95%;"></textarea>
  818. </div>
  819. <div id="modify_note">
  820. <textarea id="id_text_note" rows="7" col="28" style="margin-left: 3px; margin-right: 3px; width: 95%;"></textarea>
  821. </div>
  822. <div id="modify_spell">
  823. <span id="id_text_id"></span><br/>
  824. <?php echo $_local->gui->show;?><br />
  825. <input type="input" id="id_text_pali" onkeydown="match_key(this)" onkeyup="unicode_key(this)" /><br/>
  826. <?php echo $_local->gui->spell;?><br />
  827. <input type="input" id="id_text_real" onkeydown="match_key(this)" onkeyup="unicode_key(this)" /><br/>
  828. <br/>
  829. </div>
  830. <div id="modify_apply">
  831. </div>
  832. </div>
  833. </div>
  834. <!--逐词解析编辑窗口结束-->
  835. <!--译文编辑窗口-->
  836. <div id="id_text_edit_form">
  837. <div id="id_text_edit_caption" class="dialog-title">
  838. <div><button id="id_text_edit_cancel" type="button" onclick="edit_tran_cancal()"><?php echo $_local->gui->cancel;?></button></div>
  839. <div><span id="id_text_edit_caption_text">
  840. <?php echo $_local->gui->translation; ?></span></div>
  841. <div id="id_text_edit_bottom">
  842. <button id="id_text_edit_delete" type="button" onclick="edit_tran_delete()">
  843. <?php echo $_local->gui->delete;?>
  844. </button>
  845. </div>
  846. <div><button id="id_text_edit_save" type="button" onclick="edit_tran_save()"><?php echo $_local->gui->save;?></button></div>
  847. </div>
  848. <div id="id_text_edit_info">
  849. <select id="id_heading_edit_level" >
  850. <option value="0"><?php echo $_local->gui->normal;?></option>
  851. <option value="1"><?php echo $_local->gui->heading_1;?></option>
  852. <option value="2"><?php echo $_local->gui->heading_2;?></option>
  853. <option value="3"><?php echo $_local->gui->heading_3;?></option>
  854. <option value="4"><?php echo $_local->gui->heading_4;?></option>
  855. <option value="5"><?php echo $_local->gui->heading_5;?></option>
  856. <option value="6"><?php echo $_local->gui->heading_6;?></option>
  857. <option value="7"><?php echo $_local->gui->heading_7;?></option>
  858. <option value="8"><?php echo $_local->gui->heading_8;?></option>
  859. </select>
  860. <select id="id_text_edit_language">
  861. <option value="pali">Pali</option>
  862. <option value="en">English</option>
  863. <option value="zh">简体中文</option>
  864. <option value="tw">正體中文</option>
  865. </select>
  866. <span>
  867. <?php echo $_local->gui->author;?>
  868. <input type="input" id="id_text_edit_author" onkeydown="match_key(this)" onkeyup="unicode_key(this)"/>
  869. <?php echo $_local->gui->smart_spell;?>
  870. <input id="id_text_edit_area_smart_switch" type="checkbox" checked="">
  871. </span>
  872. </div>
  873. <textarea id="id_text_edit_area" rows="10" width="100%" onkeydown="match_key(this)" onkeyup="unicode_key(this)">
  874. </textarea>
  875. </div>
  876. <!-- Tool bar on right side -->
  877. <div id="right_tool_bar" >
  878. <div id="right_tool_bar_inner">
  879. <?php
  880. #头部右侧插件
  881. foreach($plugin_list as $info){
  882. if($info->attach=="top_right" && $info->enable=="true"){
  883. echo "<div id=\"{$info->id}\" >";
  884. require "plugin/{$info->dir}/gui.html";
  885. echo "</div>";
  886. }
  887. }
  888. ?>
  889. <!-- 三藏购物车 -->
  890. <div id="pc_res_loader">
  891. <div id="pc_res_load_button">
  892. <button id="id_open_editor_load_stream" onclick="pc_loadStream(0)">
  893. <svg class="button_icon"><use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="svg/icon.svg#ic_cloud_download"></use></svg>
  894. </button>
  895. <button id="id_cancel_stream" onclick="pc_cancelStream()"><?php //echo $_local->gui->cancel;?>
  896. <svg class="button_icon"><use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="svg/icon.svg#ic_note_add"></use></svg>
  897. </button>
  898. <button id="pc_empty_download_list" onclick="pc_empty_download_list()"><?php //echo $module_gui_str['editor']['1045'];?>
  899. <svg class="button_icon"><use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="svg/icon.svg#ic_delete"></use></svg>
  900. </button>
  901. <button onclick="get_pc_res_download_list_from_cookie()"><?php //echo $_local->gui->refresh;?>
  902. <svg class="button_icon"><use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="svg/icon.svg#ic_autorenew"></use></svg>
  903. </button>
  904. </div>
  905. <div id="pc_res_list_div">
  906. </div>
  907. <div id="id_book_res_load_progress"></div>
  908. <canvas id="book_res_load_progress_canvas" width="300" height="30"></canvas>
  909. </div>
  910. </div>
  911. </div>
  912. <!-- Tool bar on right side end -->
  913. <div class="pop_win_full"><div id="pop_win_inner"></div></div>
  914. <!-- Term pop window-->
  915. <div class="pop_win_full" id="term_win">
  916. <div class="pop_win_inner">
  917. <div class="win_title">
  918. <div>
  919. <button onclick="win_close('term_win')">
  920. <svg class="button_icon" style="fill: var(--btn-hover-bg-color);">
  921. <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="svg/icon.svg#ic_clear">
  922. </use>
  923. </svg>
  924. </button>
  925. </div>
  926. <div>
  927. <span>
  928. <?php echo $_local->gui->relational_map; ?>
  929. </span>
  930. </div>
  931. <div>
  932. <button onclick="term_save()">
  933. <svg class="button_icon" style="fill: var(--btn-hover-bg-color);">
  934. <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="svg/icon.svg#ic_save">
  935. </use>
  936. </svg>
  937. </button>
  938. </div>
  939. </div>
  940. <div class="win_body" id="term_body_parent">
  941. <div class="win_body_inner" id="term_body">
  942. </div>
  943. </div>
  944. </div>
  945. </div>
  946. <!-- 逐词解析下拉菜单-->
  947. <div class="display_off">
  948. <div id="word_mean" style="max-width:22em;"></div>
  949. <div id="word_parts" style="max-width:22em;"></div>
  950. <div id="word_partmean" style="max-width:22em;"></div>
  951. <div id="word_gramma" style="max-width:22em;"></div>
  952. </div>
  953. <!-- 逐词解析 词头工具栏-->
  954. <div id="word_tool_bar_div">
  955. <div id="word_tool_bar" class="word_head_bar"style="font-size: 70%">
  956. <button onclick="rela_link_click()">
  957. <?php echo $_local->gui->link; ?>
  958. </button>
  959. <button onclick="rela_link_click(false)">
  960. <?php echo $_local->gui->cancel; ?>
  961. </button>
  962. </div>
  963. </div>
  964. <div id="end_of_page" class="borderT textS textAc">
  965. <?php echo $_local->gui->page_end; ?><br>
  966. ——wikipāḷi <?php echo $_local->gui->studio; ?>——
  967. </div>
  968. <style>
  969. #word_note_pop{
  970. border-radius: 6px;
  971. width: 95%;
  972. max-height: calc(30vh);
  973. position: fixed;
  974. bottom: 10px;
  975. left: 3em;
  976. background-color: var(--drop-bg-color);
  977. overflow-y: auto;
  978. display:none;
  979. }
  980. </style>
  981. <script>
  982. function close_word_note_pop(){
  983. $("#word_note_pop").hide("500");
  984. }
  985. </script>
  986. <div id="word_note_pop">
  987. <div id="word_note_pop_title" style="background-color: var(--border-shadow);">
  988. <span onclick="close_word_note_pop()" style="display: flex;">
  989. <svg style="fill: var(--main-color);margin: 5px;height: 15px;width: 15px;" t="1597905254064" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2185" ><path d="M573.207 527.834l404.184-404.22a52.811 52.811 0 0 0 0-74.401l-2.217-2.217a52.836 52.836 0 0 0-74.413 0l-404.209 404.73-404.22-404.9a52.823 52.823 0 0 0-74.401 0l-2.217 2.217a51.915 51.915 0 0 0 0 74.414l404.22 404.377-404.22 404.22a52.823 52.823 0 0 0 0 74.402l2.217 2.217a52.811 52.811 0 0 0 74.401 0l404.22-404.22 404.22 404.22a52.823 52.823 0 0 0 74.414 0l2.217-2.217a52.811 52.811 0 0 0 0-74.401z m0 0" p-id="2186"></path>
  990. </svg>
  991. </span>
  992. </div>
  993. <div id="word_note_pop_content">
  994. </div>
  995. </div>
  996. </div>
  997. <script type="text/javascript">
  998. //侦测页面滚动
  999. var scrollEventLock=false;
  1000. var suttaDom = document.getElementById('sutta_text');
  1001. window.addEventListener('scroll',winScroll);
  1002. function winScroll(e){
  1003. if(scrollEventLock){
  1004. console.log("scroll Event Lock");
  1005. return;
  1006. }
  1007. if(getElementHeight(suttaDom)<getWindowHeight()){
  1008. return;
  1009. }
  1010. var top = getElementViewTop(suttaDom);
  1011. //console.log(Date() +"-"+top);
  1012. //top < 0 ? fixedDom.classList.add("fixed") : fixedDom.classList.remove("fixed");
  1013. if(top>-500){
  1014. scrollEventLock=true;
  1015. prev_page();
  1016. scrollEventLock=false;
  1017. //console.log("goto prev page");
  1018. }
  1019. if(getElementBottomOutsideHeight(suttaDom)<1500){
  1020. scrollEventLock=true;
  1021. next_page();
  1022. scrollEventLock=false;
  1023. //console.log("goto next page");
  1024. }
  1025. //debugOutput( document.body.scrollTop);
  1026. //debugOutput("top:"+top+"; outside:"+getElementBottomOutsideHeight(suttaDom));
  1027. //debugOutput("scrollHeight="+suttaDom.scrollHeight+ "; clientHeight="+suttaDom.clientHeight +";offsetHeight="+suttaDom.offsetHeight);
  1028. }
  1029. function getElementViewTop(element){
  1030.     var actualTop = element.offsetTop;
  1031. var elementScrollTop=GetPageScroll().y;//document.body.scrollTop;
  1032.     return actualTop-elementScrollTop;
  1033.   }
  1034. function getElementBottomOutsideHeight(element){
  1035. var winHeight=getWindowHeight();//document.body.clientHeight;
  1036. var elementHeight=getElementHeight(element);//suttaDom.scrollHeight;
  1037. var elementTop=getElementViewTop(element);
  1038. return(elementHeight+elementTop-winHeight);
  1039. }
  1040. function getElementHeight(element){
  1041. var scrW, scrH;
  1042. if(element.innerHeight && element.scrollMaxY)
  1043. { // Mozilla
  1044. scrW = element.innerWidth + element.scrollMaxX;
  1045. scrH = element.innerHeight + element.scrollMaxY;
  1046. }
  1047. else if(element.scrollHeight > element.offsetHeight)
  1048. { // all but IE Mac
  1049. scrW = element.scrollWidth;
  1050. scrH = element.scrollHeight;
  1051. } else if(element)
  1052. { // IE Mac
  1053. scrW = element.offsetWidth;
  1054. scrH = element.offsetHeight;
  1055. }
  1056. return(scrH);
  1057. }
  1058. function getWindowHeight(){
  1059. var winW, winH;
  1060. if(window.innerHeight)
  1061. { // all except IE
  1062. winW = window.innerWidth;
  1063. winH = window.innerHeight;
  1064. } else if (document.documentElement && document.documentElement.clientHeight)
  1065. { // IE 6 Strict Mode
  1066. winW = document.documentElement.clientWidth;
  1067. winH = document.documentElement.clientHeight;
  1068. } else if (document.body) { // other
  1069. winW = document.body.clientWidth;
  1070. winH = document.body.clientHeight;
  1071. }
  1072. return(winH);
  1073. }
  1074. //滚动条位置
  1075. function GetPageScroll()
  1076. {
  1077. var pos=new Object();
  1078. var x, y;
  1079. if(window.pageYOffset)
  1080. { // all except IE
  1081. y = window.pageYOffset;
  1082. x = window.pageXOffset;
  1083. } else if(document.documentElement && document.documentElement.scrollTop)
  1084. { // IE 6 Strict
  1085. y = document.documentElement.scrollTop;
  1086. x = document.documentElement.scrollLeft;
  1087. } else if(document.body) { // all other IE
  1088. y = document.body.scrollTop;
  1089. x = document.body.scrollLeft;
  1090. }
  1091. pos.x=x;
  1092. pos.y=y;
  1093. return(pos);
  1094. }
  1095. var Dragging=function(validateHandler){
  1096. //参数为验证点击区域是否为可移动区域,如果是返回欲移动元素,负责返回null
  1097. var draggingObj=null;
  1098. //dragging Dialog
  1099. var diffX=0;
  1100. var diffY=0;
  1101. function mouseHandler(e){
  1102. switch(e.type){
  1103. case 'mousedown':
  1104. draggingObj=validateHandler(e);
  1105. //验证是否为可点击移动区域
  1106. if(draggingObj!=null){
  1107. diffX=e.clientX-draggingObj.offsetLeft;
  1108. diffY=e.clientY-draggingObj.offsetTop;
  1109. }
  1110. break;
  1111. case 'mousemove':
  1112. if(draggingObj){
  1113. draggingObj.style.left=(e.clientX-diffX)+'px';
  1114. draggingObj.style.top=(e.clientY-diffY)+'px';
  1115. }
  1116. break;
  1117. case 'mouseup':
  1118. draggingObj =null;
  1119. diffX=0;
  1120. diffY=0;
  1121. break;
  1122. }
  1123. }
  1124. ;
  1125. return {
  1126. enable:function(){
  1127. document.addEventListener('mousedown',mouseHandler);
  1128. document.addEventListener('mousemove',mouseHandler);
  1129. document.addEventListener('mouseup',mouseHandler);
  1130. }
  1131. , disable:function(){
  1132. document.removeEventListener('mousedown',mouseHandler);
  1133. document.removeEventListener('mousemove',mouseHandler);
  1134. document.removeEventListener('mouseup',mouseHandler);
  1135. }
  1136. }
  1137. }
  1138. function getDraggingDialog(e){
  1139. try{
  1140. var target=e.target;
  1141. if(target && target.className){
  1142. while(target ){
  1143. if(target.className){
  1144. if(target.className.indexOf('dialog-title')==-1){
  1145. target=target.offsetParent;
  1146. }
  1147. else{
  1148. break;
  1149. }
  1150. }
  1151. else{
  1152. target=target.offsetParent;
  1153. }
  1154. }
  1155. if(target!=null){
  1156. return target.offsetParent;
  1157. }
  1158. else{
  1159. return null;
  1160. }
  1161. }
  1162. }
  1163. catch(e){
  1164. }
  1165. }
  1166. // Dragging(getDraggingDialog).enable();
  1167. </script>
  1168. <script language="javascript" src="module/editor/language/<?php echo $currLanguage; ?>.js"></script>
  1169. <script language="javascript" src="module/editor_palicannon/palicannon.js"></script>
  1170. <script language="javascript" src="module/editor_palicannon/language/<?php echo $currLanguage; ?>.js"></script>
  1171. <script language="javascript" src="module/editor_toc/module_function.js"></script>
  1172. <script language="javascript" src="module/editor_toc/language/<?php echo $currLanguage; ?>.js"></script>
  1173. <script language="javascript" src="module/editor_bookmark/module_function.js"></script>
  1174. <script language="javascript" src="module/editor_bookmark/language/<?php echo $currLanguage; ?>.js"></script>
  1175. <script language="javascript" src="module/editor_layout/module_function.js"></script>
  1176. <script language="javascript" src="module/editor_layout/language/<?php echo $currLanguage; ?>.js"></script>
  1177. <script language="javascript" src="module/editor_project/module_function.js"></script>
  1178. <script language="javascript" src="module/editor_project/language/<?php echo $currLanguage; ?>.js"></script>
  1179. <script language="javascript" src="module/editor_dictionary/module_function.js"></script>
  1180. <script language="javascript" src="module/editor_dictionary/language/<?php echo $currLanguage; ?>.js"></script>
  1181. <script language="javascript" src="module/editor_plugin/module_function.js"></script>
  1182. <script language="javascript" src="module/editor_plugin/language/<?php echo $currLanguage; ?>.js"></script>
  1183. <script>
  1184. guide_init();
  1185. </script>
  1186. </body>
  1187. </html>