editor.php 40 KB

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