reader.php 33 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871
  1. <?php
  2. require_once "../public/_pdo.php";
  3. require_once "../path.php";
  4. require_once '../public/load_lang.php';
  5. ?>
  6. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
  7. <html>
  8. <head>
  9. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
  10. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  11. <link type="text/css" rel="stylesheet" href="../studio/css/font.css"/>
  12. <link type="text/css" rel="stylesheet" href="css/reader.css"/>
  13. <link type="text/css" rel="stylesheet" href="css/reader_mob.css" media="screen and (max-width:767px)">
  14. <title id="page_title">PCD Reader</title>
  15. <script src="js/jquery-3.3.1.min.js"></script>
  16. <script src="js/fixedsticky.js"></script>
  17. <script src="js/reader.js"></script>
  18. <script src="../public/js/comm.js"></script>
  19. <script src="../term/term.js"></script>
  20. <script src="../term/note.js"></script>
  21. <body class="reader_body" >
  22. <script type="text/javascript">
  23. $(document).ready(function(){
  24. $(".toc_1_title").click(function(){
  25. $(".toc_2").hide();
  26. $(this).siblings().slideDown("200");
  27. });
  28. });
  29. </script>
  30. <style>
  31. #para_nav {
  32. display: flex;
  33. justify-content: space-between;
  34. padding: 5px 1em;
  35. border-top: 1px solid gray;
  36. }
  37. .word{
  38. display:inline-block;
  39. padding: 1px 3px;
  40. }
  41. .mean{
  42. font-size: 65%;
  43. }
  44. /* 下拉内容 (默认隐藏) */
  45. #mean_menu {
  46. margin: 0.3em;
  47. position: absolute;
  48. background-color: white;
  49. min-width: 8em;
  50. max-width: 30em;
  51. margin: -1px 0px;
  52. box-shadow: 0px 3px 13px 0px black;
  53. color: var(--main-color);
  54. z-index: 200;
  55. }
  56. /* 下拉菜单的链接 */
  57. #mean_menu a {
  58. /*padding: 0.3em 0.4em;*/
  59. line-height: 160%;
  60. text-decoration: none;
  61. display: block;
  62. cursor: pointer;
  63. text-align: left;
  64. font-size:80%;
  65. }
  66. /* 鼠标移上去后修改下拉菜单链接颜色 */
  67. .mean_menu a:hover {
  68. background-color: blue;
  69. color: white;
  70. }
  71. .par_pali_div{
  72. margin-top:1em;
  73. }
  74. .par_pali_div{
  75. font-weight:700;
  76. }
  77. sent{
  78. font-weight:500;
  79. font-size:110%;
  80. line-height: 150%;
  81. }
  82. sent:hover{
  83. background-color:#fefec1;
  84. }
  85. para {
  86. color: white;
  87. background-color: #F1CA23;
  88. min-width: 2em;
  89. display: inline-block;
  90. text-align: center;
  91. padding: 3px 6px;
  92. border-radius: 99px;
  93. margin-right: 5px;
  94. cursor:pointer;
  95. font-size:80%;
  96. }
  97. para:hover{
  98. }
  99. .sent_count{
  100. font-size:80%;
  101. color: white;
  102. background-color: #1cb70985;
  103. min-width: 2em;
  104. display: inline-block;
  105. text-align: center;
  106. padding: 2px 0;
  107. border-radius: 99px;
  108. margin-left: 5px;
  109. cursor:pointer;
  110. }
  111. .toc_1{
  112. padding: 5px;
  113. cursor: pointer;
  114. }
  115. .toc_1_title{
  116. font-weight:700;
  117. }
  118. .toc_2{
  119. font-weight:500;
  120. padding-left:1em;
  121. display:none;
  122. }
  123. .curr_chapter{
  124. background-color:#e1e1e1;
  125. }
  126. .toc_curr_chapter2{
  127. display:block;
  128. }
  129. .toc_title2 a{
  130. color:black;
  131. line-height:1.4em;
  132. text-decoration: none;
  133. }
  134. .toc_title2 a:hover{
  135. text-decoration: underline;
  136. }
  137. .curr_chapter_title2{
  138. background-color:#F1CA23;
  139. }
  140. #leftmenuinner{
  141. width: 17em;
  142. }
  143. #leftmenuinnerinner{
  144. overflow-y: scroll;
  145. }
  146. .sent_toc{
  147. font-weight:700;
  148. font-size:120%;
  149. }
  150. </style>
  151. <!-- tool bar begin-->
  152. <div id="main_tool_bar" class='reader_toolbar'>
  153. <div id="index_nav">
  154. <button onclick="setNaviVisibility()">
  155. <svg t='1598084571450' class='icon' viewBox='0 0 1029 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='6428' width='20px' height='20px'><path d='M159.744 69.632 53.248 69.632C28.672 69.632 4.096 90.112 4.096 118.784l0 94.208c0 28.672 24.576 49.152 53.248 49.152l102.4 0C184.32 266.24 208.896 241.664 208.896 212.992L208.896 118.784C208.896 90.112 184.32 69.632 159.744 69.632zM970.752 69.632 368.64 69.632c-28.672 0-57.344 24.576-57.344 49.152l0 94.208c0 28.672 32.768 49.152 57.344 49.152l598.016 0c28.672 0 57.344-24.576 57.344-49.152L1024 118.784C1028.096 94.208 999.424 69.632 970.752 69.632zM159.744 413.696 53.248 413.696c-28.672 0-53.248 24.576-53.248 49.152l0 94.208c0 28.672 24.576 49.152 53.248 49.152l102.4 0c28.672 0 53.248-24.576 53.248-49.152l0-94.208C208.896 438.272 184.32 413.696 159.744 413.696zM970.752 413.696 368.64 413.696c-28.672 0-57.344 24.576-57.344 49.152l0 94.208c0 28.672 32.768 49.152 57.344 49.152l598.016 0c28.672 0 57.344-24.576 57.344-49.152l0-94.208C1028.096 438.272 999.424 413.696 970.752 413.696zM159.744 757.76 53.248 757.76c-28.672 0-53.248 24.576-53.248 49.152l0 94.208c0 28.672 24.576 49.152 53.248 49.152l102.4 0c28.672 0 53.248-24.576 53.248-49.152l0-94.208C208.896 782.336 184.32 757.76 159.744 757.76zM970.752 761.856 368.64 761.856c-28.672 0-57.344 24.576-57.344 49.152l0 94.208c0 28.672 32.768 49.152 57.344 49.152l598.016 0c28.672 0 57.344-24.576 57.344-49.152l0-94.208C1028.096 782.336 999.424 761.856 970.752 761.856z' fill='#757AF7' p-id='6429'></path></svg>
  156. </button>
  157. </div>
  158. <div>
  159. <span id="tool_bar_title" style="font-family: 'Noto Serif';"><?php echo $_local->gui->title; ?></span>
  160. </div>
  161. <div style="display: flex;">
  162. <form action="../studio/project.php" method="post" onsubmit="return pali_canon_edit_now(this)" target="_blank" style="display: inline-block;">
  163. <div style="display:none;">
  164. <input type="input" name="op" value="create">
  165. <input type="hidden" name="view" value="<?php echo $_GET["view"]?>" />
  166. <input type="hidden" name="book" value="<?php echo $_GET["book"]?>" />
  167. <input type="hidden" id = "para" name="para" value="" />
  168. <input type="hidden" id = "para_end" name="para_end" value="" />
  169. <input type="hidden" id = "chapter_title" name="chapter_title" value="" />
  170. <textarea id="project_new_res_data" rows="3" cols="18" name="data"></textarea>
  171. </div>
  172. <input type="submit" value="<?php echo $_local->gui->edit_now; ?>">
  173. </form>
  174. <div class="case_dropdown">
  175. <p class="case_dropbtn"><button>
  176. <svg t='1598086376923' class='icon' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='8426' width='20px' height='20px'><path d='M609.745455 453.818182v130.327273h69.818181V535.272727H744.727273v377.018182h95.418182V535.272727H907.636364v48.872728h69.818181V453.818182z' p-id='8427' fill='#757AF7'></path><path d='M677.236364 300.218182V111.709091H46.545455V300.218182h69.818181v-51.2h162.909091v663.272727h165.236364V249.018182h162.909091v51.2z' p-id='8428' fill='#757AF7'></path></svg>
  177. </button></p>
  178. <div class="case_dropdown-content" style="right: 0;width:10em;">
  179. <div ><button>A+</button><button>A-</button></div>
  180. <div ><button><?php echo $_local->gui->white;?></button><button><?php echo $_local->gui->dawn;//棕?></button><button><?php echo $_local->gui->night;//夜?></button></div>
  181. </div>
  182. </div>
  183. <div class="case_dropdown">
  184. <p class="case_dropbtn"><button>
  185. <svg t='1598086493824' class='icon' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='9217' width='20px' height='20px'><path d='M912.695652 512m-111.304348 0a5 5 0 1 0 222.608696 0 5 5 0 1 0-222.608696 0Z' p-id='9218' fill='#757AF7'></path><path d='M512 512m-111.304348 0a5 5 0 1 0 222.608696 0 5 5 0 1 0-222.608696 0Z' p-id='9219' fill='#757AF7'></path><path d='M111.304348 512m-111.304348 0a5 5 0 1 0 222.608696 0 5 5 0 1 0-222.608696 0Z' p-id='9220' fill='#757AF7'></path></svg>
  186. </button></p>
  187. <div class="case_dropdown-content" style="right: 2em;min-width:6em;">
  188. <a onclick="tool_changed('dighest')"><?php echo $_local->gui->digest; //书摘?></a>
  189. <a onclick="tool_changed('comments')"><?php echo $_local->gui->comment; //批注?></a>
  190. <a onclick="tool_changed('target')"><?php echo $_local->gui->tag; //标签?></a>
  191. <a onclick="tool_changed('layout')"><?php echo $_local->gui->layout; //布局?></a>
  192. <a onclick="tool_changed('porpername')"><?php echo $_local->gui->dict_terms; //术语?></a>
  193. <a onclick="tool_changed('share')"><?php echo $_local->gui->share; //分享?></a>
  194. <a onclick="tool_changed('fix')"><?php echo $_local->gui->modify; //修改?></a>
  195. </div>
  196. </div>
  197. </div>
  198. </div>
  199. <div id="tool_bar_comments">
  200. <div class='reader_toolbar' style="height:auto;">
  201. <div>
  202. </div>
  203. <div>
  204. <span>单击段落文字添加批注</span>
  205. </div>
  206. <div>
  207. </div>
  208. </div>
  209. </div>
  210. <div id="tool_bar_dighest">
  211. <div class='reader_toolbar' style="height:auto;">
  212. <div>
  213. <button onclick="dighest_cancle()">取消</button>
  214. </div>
  215. <div>
  216. <span id="dighest_message">单击文字选择段落</span>
  217. </div>
  218. <div>
  219. <button onclick="dighest_ok()">完成</button>
  220. </div>
  221. </div>
  222. </div>
  223. <div id="tool_bar_fix">
  224. <div class='reader_toolbar' style="height:auto;">
  225. <div>
  226. <button onclick="fix_cancle()">取消</button>
  227. </div>
  228. <div>
  229. <span id="fix_message">单击按钮调整段落</span>
  230. </div>
  231. <div>
  232. <button onclick="fix_ok()">完成</button>
  233. </div>
  234. </div>
  235. </div>
  236. <!--tool bar end -->
  237. <div id="main_text_view" style="padding-bottom: 10em;">
  238. <?php
  239. $tocHtml="";
  240. if(isset($_GET["album"])){
  241. $album=$_GET["album"];
  242. }
  243. if(isset($_GET["book"])){
  244. $book=$_GET["book"];
  245. }
  246. else{
  247. echo "no book id";
  248. }
  249. if(substr($book,0,1)=='p'){
  250. $book=substr($book,1);
  251. }
  252. if(isset($_GET["paragraph"])){
  253. $paragraph = $_GET["paragraph"];
  254. }
  255. else if(isset($_GET["para"])){
  256. $paragraph = $_GET["para"];
  257. }
  258. else{
  259. $paragraph = -1;
  260. }
  261. if(isset($_GET["view"])){
  262. $_view = $_GET["view"];
  263. }
  264. else{
  265. echo "Error : 未定义必要的参数view";
  266. exit;
  267. }
  268. if(isset($_GET["display"])){
  269. $_display = $_GET["display"];
  270. }
  271. else{
  272. if($_view=="para" || $_view=="sent"){
  273. $_display = "sent";//默认值
  274. }
  275. else{
  276. $_display = "para";
  277. }
  278. }
  279. $tocList = array();
  280. if($_view=="chapter" || $_view=="para" || $_view=="sent" ){
  281. PDO_Connect("sqlite:"._FILE_DB_PALITEXT_);
  282. //生成目录
  283. $htmlToc2 = "";
  284. //找到该位置对应的书
  285. $query = "select paragraph,level,chapter_len,parent from 'pali_text' where book='$book' and paragraph='$paragraph'";
  286. $FetchParInfo = PDO_FetchAll($query);
  287. $deep = 0;
  288. if(count($FetchParInfo)>0){
  289. $para = $FetchParInfo[0]["paragraph"];
  290. $level = $FetchParInfo[0]["level"];
  291. $chapter_len = $FetchParInfo[0]["chapter_len"];
  292. $parent = $FetchParInfo[0]["parent"];
  293. $currParaBegin = $para;
  294. $currParaEnd = $para + $chapter_len;
  295. //循环查找父标题 得到整条路径
  296. while($parent>-1){
  297. $query = "select paragraph,level,parent,chapter_len from pali_text where \"book\" = '{$book}' and \"paragraph\" = '{$parent}' limit 0,1";
  298. $FetParent = PDO_FetchAll($query);
  299. if(count($FetParent)>0){
  300. $para = $FetParent[0]["paragraph"];
  301. $level = $FetParent[0]["level"];
  302. $chapter_len = $FetParent[0]["chapter_len"];
  303. $parent = $FetParent[0]["parent"];
  304. }
  305. $deep++;
  306. if($deep>8){
  307. break;
  308. }
  309. }
  310. $paraBegin = $para+1;
  311. $paraEnd = $para+$chapter_len;
  312. $query = "SELECT toc,paragraph,level,chapter_len,parent FROM 'pali_text' WHERE book='$book' AND (paragraph BETWEEN '$paraBegin' AND '$paraEnd') and level<100";
  313. $chapter_toc = PDO_FetchAll($query);
  314. $tocMaxLevel = 0;
  315. $tocMinLevel = 0;
  316. echo "<div><div>";
  317. foreach ($chapter_toc as $key => $value) {
  318. $classCurrToc="";
  319. $classCurrToc2 = "";
  320. $classCurrTocTitle2="";
  321. if($paragraph>=$value["paragraph"] && $paragraph<$value["paragraph"]+$value["chapter_len"]){
  322. $classCurrToc = " curr_chapter";
  323. $classCurrToc2 = " toc_curr_chapter2";
  324. $classCurrTocTitle2=" curr_chapter_title2";
  325. }
  326. if($tocMaxLevel==0){
  327. $tocMaxLevel =$value["level"];
  328. }
  329. if($tocMinLevel==0){
  330. if($value["level"]>$tocMaxLevel){
  331. $tocMinLevel = $value["level"];
  332. $tocHtml .= "<div class='toc_title2 {$classCurrToc}{$classCurrTocTitle2}'><a href='reader.php?view=chapter&book={$book}&para={$value["paragraph"]}&display={$_display}'>{$value["toc"]}</a></div>";
  333. }
  334. else{
  335. $tocHtml .= "</div></div><div class='toc_1 {$classCurrToc}'>";
  336. $tocHtml .= "<div class='toc_1_title'>{$value["toc"]}</div><div class='toc_2 $classCurrToc2'>";
  337. }
  338. }
  339. else{
  340. if($value["level"] == $tocMaxLevel){
  341. $tocHtml .= "</div></div><div class='toc_1 {$classCurrToc}'>";
  342. $tocHtml .= "<div class='toc_1_title'>{$value["toc"]}</div><div class='toc_2 $classCurrToc2' >";
  343. }
  344. else if($value["level"] == $tocMinLevel){
  345. $tocHtml .= "<div class='toc_title2 {$classCurrToc}{$classCurrTocTitle2}'><a href='reader.php?view=chapter&book={$book}&para={$value["paragraph"]}&display={$_display}'>{$value["toc"]}</a></div>";
  346. }
  347. }
  348. //右侧目录
  349. if($value["paragraph"]>$currParaBegin && $value["paragraph"]<$currParaEnd){
  350. $tocList[$value["paragraph"]] = $value["level"];
  351. $htmlToc2 .= "<div><a href='#para_{$value["paragraph"]}'>{$value["toc"]}</a></div>";
  352. }
  353. }
  354. echo " </div></div>";
  355. }
  356. //获取段落信息 如 父段落 下一个段落等
  357. $query = "select * from 'pali_text' where book='$book' and paragraph='$paragraph'";
  358. $FetchParInfo = PDO_FetchAll($query);
  359. if(count($FetchParInfo)==0){
  360. echo "Error:no paragraph info";
  361. echo $query;
  362. }
  363. $currLevel = $FetchParInfo[0]["level"];
  364. $par_begin=$paragraph+1-1;
  365. if($_view=="para"){
  366. $par_end = $par_begin;
  367. }
  368. else{
  369. $par_end=$par_begin+$FetchParInfo[0]["chapter_len"]-1;
  370. }
  371. $par_next=$FetchParInfo[0]["next_chapter"];
  372. $par_prev=$FetchParInfo[0]["prev_chapter"];
  373. $par_parent=$FetchParInfo[0]["parent"];
  374. if($par_parent >= 0){
  375. $query = "select toc from 'pali_text' where book='$book' and paragraph='$par_parent'";
  376. $FetchToc = PDO_FetchAll($query);
  377. if(count($FetchToc)>0){
  378. $_parent_title = $FetchToc[0]["toc"];
  379. }
  380. }
  381. //查询标题
  382. if($_view=="chapter"){
  383. $par_title = $FetchParInfo[0]["toc"];
  384. }
  385. else{
  386. $par_title = $_parent_title;
  387. }
  388. //导航按钮
  389. if($_view=="sent"){
  390. $next_para_link = "";
  391. $prev_para_link = "";
  392. }
  393. else{
  394. if($par_next != -1){
  395. $query = "select paragraph , toc from 'pali_text' where book='$book' and paragraph='$par_next' ";
  396. $FetchPara = PDO_FetchAll($query);
  397. if(count($FetchPara)>0){
  398. $next_para_link = "<a href='reader.php?view={$_view}&book={$book}&para={$par_next}&display={$_display}'><span id='para_nav_next'>{$FetchPara[0]["toc"]}</span><span id='para_nav_next_a'>";
  399. $next_para_link .= "<svg t='1598093121925' class='icon' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='4451' width='32px' height='32px'><path d='M540.5696 102.4c-225.83296 0-409.6 183.74656-409.6 409.6s183.76704 409.6 409.6 409.6c225.85344 0 409.6-183.74656 409.6-409.6s-183.74656-409.6-409.6-409.6z m180.14208 439.84896l-109.19936 128.59392a46.65344 46.65344 0 0 1-65.86368 5.36576 46.71488 46.71488 0 0 1-5.38624-65.8432l43.86816-51.63008h-188.12928a46.6944 46.6944 0 1 1 0-93.42976h188.12928l-43.86816-51.63008a46.75584 46.75584 0 0 1 71.24992-60.47744l109.19936 128.59392c14.82752 17.408 14.82752 43.008 0 60.45696z' p-id='4452' fill='#757AF7'></path></svg>";
  400. $next_para_link .= "</span></a>";
  401. }
  402. else{
  403. $next_para_link = $_local->gui->text_without_title;
  404. }
  405. }
  406. else{
  407. $next_para_link = $_local->gui->end_of_text;
  408. }
  409. if($par_prev != -1){
  410. $query = "select paragraph , toc from 'pali_text' where book='$book' and paragraph='$par_prev' ";
  411. $FetchPara = PDO_FetchAll($query);
  412. if(count($FetchPara)>0){
  413. $prev_para_link = "<a href='reader.php?view={$_view}&book={$book}&para={$par_prev}&display={$_display}'><span id='para_nav_prev_a'>";
  414. $prev_para_link .= "<svg t='1598093521111' class='icon' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='4644' width='32' height='32'><path d='M540.5696 102.4c-225.83296 0-409.6 183.74656-409.6 409.6s183.76704 409.6 409.6 409.6c225.85344 0 409.6-183.74656 409.6-409.6s-183.74656-409.6-409.6-409.6z m144.54784 456.31488h-188.12928l43.84768 51.63008a46.6944 46.6944 0 0 1-35.59424 76.96384 46.55104 46.55104 0 0 1-35.61472-16.4864l-109.24032-128.59392a46.71488 46.71488 0 0 1 0-60.47744l109.24032-128.59392a46.6944 46.6944 0 1 1 71.20896 60.47744l-43.84768 51.63008h188.12928a46.6944 46.6944 0 1 1 0 93.45024z' p-id='4645' fill='#757AF7'></path></svg>";
  415. if($FetchPara[0]["toc"]==""){
  416. $prev_para_link .= "</span><span id='para_nav_prev'>({$_local->gui->text_without_title})</span></a>";
  417. }
  418. else{
  419. $prev_para_link .= "</span><span id='para_nav_prev'>{$FetchPara[0]["toc"]}</span></a>";
  420. }
  421. }
  422. else{
  423. $prev_para_link = $_local->gui->text_without_title;
  424. }
  425. }
  426. else{
  427. $prev_para_link = $_local->gui->begin_of_text;
  428. }
  429. }
  430. //设置标题栏的经文名称
  431. echo "<script>";
  432. echo "document.getElementById('tool_bar_title').innerHTML='".$par_title."';\n";
  433. echo "$('#chapter_title').val('".$par_title."');\n";
  434. echo "$('#para_end').val('".$par_end."');\n";
  435. echo "$('#para').val('".$par_begin."');\n";
  436. echo "</script>";
  437. }
  438. if($currLevel<$tocMinLevel){
  439. echo $_local->gui->chapter_select;
  440. }
  441. else{
  442. //上一级
  443. echo "<div>";
  444. switch($_view){
  445. case 1 :
  446. break;
  447. case 2:
  448. break;
  449. case 3:
  450. break;
  451. case 4:
  452. break;
  453. case 5:
  454. break;
  455. case 5:
  456. break;
  457. case 6:
  458. break;
  459. case "chapter":
  460. if($par_parent >= 0 && $currLevel>$tocMinLevel){
  461. echo "<a href='reader.php?view={$_view}&book={$book}&paragraph={$par_parent}'>";
  462. echo "<svg t='1598083209786' class='icon' style='fill:#666666;' height='30px' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='4926'><path d='M446.464 118.784l-254.976 256c-13.312 13.312-4.096 35.84 15.36 35.84H716.8c18.432 0 28.672-22.528 15.36-35.84l-254.976-256c-9.216-8.192-22.528-8.192-30.72 0zM563.2 796.672V533.504c0-11.264-9.216-21.504-21.504-21.504H379.904c-11.264 0-21.504 9.216-21.504 21.504v366.592c0 11.264 9.216 21.504 21.504 21.504h467.968c11.264 0 21.504-9.216 21.504-21.504V839.68c0-11.264-9.216-21.504-21.504-21.504H584.704c-12.288 0-21.504-9.216-21.504-21.504z m0 21.504' p-id='4927'></path></svg>";
  463. echo "{$_parent_title}</a>";
  464. }
  465. break;
  466. case "para":
  467. if($par_parent >= 0){
  468. echo "<a href='reader.php?view=chapter&book={$book}&paragraph={$par_parent}'>";
  469. echo "<svg t='1598083209786' class='icon' style='fill:#666666;' height='30px' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='4926'><path d='M446.464 118.784l-254.976 256c-13.312 13.312-4.096 35.84 15.36 35.84H716.8c18.432 0 28.672-22.528 15.36-35.84l-254.976-256c-9.216-8.192-22.528-8.192-30.72 0zM563.2 796.672V533.504c0-11.264-9.216-21.504-21.504-21.504H379.904c-11.264 0-21.504 9.216-21.504 21.504v366.592c0 11.264 9.216 21.504 21.504 21.504h467.968c11.264 0 21.504-9.216 21.504-21.504V839.68c0-11.264-9.216-21.504-21.504-21.504H584.704c-12.288 0-21.504-9.216-21.504-21.504z m0 21.504' p-id='4927'></path></svg>";
  470. echo "{$_parent_title}</a>";
  471. }
  472. break;
  473. case "sent":
  474. echo "<a href='reader.php?view=para&book={$book}&paragraph={$paragraph}'>";
  475. echo "<svg t='1598083209786' class='icon' style='fill:#666666;' height='30px' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='4926'><path d='M446.464 118.784l-254.976 256c-13.312 13.312-4.096 35.84 15.36 35.84H716.8c18.432 0 28.672-22.528 15.36-35.84l-254.976-256c-9.216-8.192-22.528-8.192-30.72 0zM563.2 796.672V533.504c0-11.264-9.216-21.504-21.504-21.504H379.904c-11.264 0-21.504 9.216-21.504 21.504v366.592c0 11.264 9.216 21.504 21.504 21.504h467.968c11.264 0 21.504-9.216 21.504-21.504V839.68c0-11.264-9.216-21.504-21.504-21.504H584.704c-12.288 0-21.504-9.216-21.504-21.504z m0 21.504' p-id='4927'></path></svg>";
  476. echo "{$paragraph}</a>";
  477. break;
  478. case 10:
  479. break;
  480. }
  481. echo "</div>";
  482. //生成一个段落空壳 等会儿查询数据,按照不同数据类型填充进去
  483. PDO_Connect("sqlite:"._FILE_DB_PALI_SENTENCE_);
  484. if($_display=="sent"){
  485. //逐句显示
  486. for($iPar=$par_begin;$iPar<=$par_end;$iPar++){
  487. if($_view=="sent"){
  488. $query = "select text, begin, end from 'pali_sent' where book='$book' and paragraph='$paragraph' and begin='{$_GET["begin"]}' and end ='{$_GET["end"]}'";
  489. }
  490. else{
  491. $query = "select text, begin, end from 'pali_sent' where book='$book' and paragraph='$iPar'";
  492. }
  493. if(isset($tocList[$iPar])){
  494. $sentClass = " sent_toc";
  495. }
  496. else{
  497. $sentClass = "";
  498. }
  499. $FetchSent = PDO_FetchAll($query);
  500. echo "<div id='par-b$book-$iPar' class='par_div'>";
  501. echo "<para book='$book' para='$iPar'>$iPar</para><a name='para_{$iPar}'></a>";
  502. foreach ($FetchSent as $key => $value) {
  503. echo "<div id='sent-pali-b$book-$iPar-{$value["begin"]}' class='par_pali_div'>";
  504. $pali_sent = str_replace("{","<b>",$value["text"]);
  505. $pali_sent = str_replace("}","</b>",$pali_sent);
  506. echo "<sent class='{$sentClass}' book='{$book}' para='{$iPar}' begin='{$value["begin"]}' end='{$value["end"]}' >".$pali_sent."</sent>";
  507. echo "</div>";
  508. echo "<div id='sent-wbwdiv-b$book-$iPar-{$value["begin"]}' class='par_translate_div'>";
  509. echo "</div>";
  510. echo "<div id='sent-translate-b$book-$iPar-{$value["begin"]}' class='par_translate_div'>";
  511. echo "</div>";
  512. }
  513. echo "</div>";
  514. }
  515. }
  516. else{
  517. //段落显示
  518. for($iPar=$par_begin;$iPar<=$par_end;$iPar++){
  519. if(isset($tocList[$iPar])){
  520. $sentClass = " sent_toc";
  521. }
  522. else{
  523. $sentClass = "";
  524. }
  525. $query = "select text , begin, end from 'pali_sent' where book='$book' and paragraph='$iPar'";
  526. $FetchSent = PDO_FetchAll($query);
  527. echo "<div id='par-b$book-$iPar' class='par_div'>";
  528. echo "<div id='par-pali-b$book-$iPar' class='par_pali_div'>";
  529. echo "<para book='$book' para='$iPar'>$iPar</para><a name='para_{$iPar}'></a>";
  530. foreach ($FetchSent as $key => $value) {
  531. $sent_text = str_replace("{","<b>",$value["text"]) ;
  532. $sent_text = str_replace("}","</b>",$sent_text) ;
  533. echo "<sent class='{$sentClass}' book='{$book}' para='{$iPar}' begin='{$value["begin"]}' end='{$value["end"]}' >{$sent_text}</sent>";
  534. }
  535. echo "</div>";
  536. echo "<div id='par-wbwdiv-b$book-$iPar' class='par_translate_div'>";
  537. echo "</div>";
  538. echo "<div id='par-translate-b$book-$iPar' class='par_translate_div'>";
  539. echo "</div>";
  540. echo "<div id='par-note-b$book-$iPar' class='par_translate_div'>";
  541. echo "</div>";
  542. echo "</div>";
  543. }
  544. }
  545. if(isset($_GET["sent_mode"])){
  546. }
  547. PDO_Connect("sqlite:"._FILE_DB_SENTENCE_);
  548. $dbh = new PDO("sqlite:"._FILE_DB_PALI_SENTENCE_, "", "");
  549. $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_WARNING);
  550. for($iPar=$par_begin;$iPar<=$par_end;$iPar++){
  551. if($_view=="sent"){
  552. $FetchPaliSent = array(array("begin" => $_GET["begin"] , "end" => $_GET["end"]));
  553. }
  554. else{
  555. $query = "select begin, end from 'pali_sent' where book='$book' and paragraph='$iPar'";
  556. $stmt = $dbh->query($query);
  557. $FetchPaliSent = $stmt->fetchAll(PDO::FETCH_ASSOC);
  558. }
  559. foreach ($FetchPaliSent as $key => $value) {
  560. $begin = $value["begin"];
  561. $end = $value["end"];
  562. if($_view=="sent"){
  563. $query="SELECT * FROM \"sentence\" WHERE (book = '{$book}' AND \"paragraph\" = ".$PDO->quote($iPar)." AND begin = '$begin' AND end = '$end' AND length(text)>0 ) order by modify_time DESC";
  564. }
  565. else{
  566. $query = "SELECT * FROM \"sentence\" WHERE book = '{$book}' AND \"paragraph\" = ".$PDO->quote($iPar)." AND begin = '$begin' AND end = '$end' AND length(text)>0 order by modify_time DESC limit 0, 1";
  567. }
  568. $query_count = "SELECT count(book) FROM \"sentence\" WHERE book = '{$book}' AND \"paragraph\" = ".$PDO->quote($iPar)." AND begin = '$begin' AND end = '$end' AND length(text)>0 ";
  569. $sent_count = PDO_FetchOne($query_count);
  570. if($sent_count>9){
  571. $sent_count = "9+";
  572. }
  573. $FetchText = PDO_FetchAll($query);
  574. $iFetchText=count($FetchText);
  575. if($iFetchText>0){
  576. for($i=0;$i<$iFetchText;$i++){
  577. $currParNo=$iPar;
  578. if($_display=="sent"){
  579. $sent_style = "display:block";
  580. }
  581. else{
  582. $sent_style = "";
  583. }
  584. $tran_text = str_replace("[[","<term status='0'>",$FetchText[$i]["text"]);
  585. $tran_text = str_replace("]]","</term>",$tran_text);
  586. echo "<sent_trans style='{$sent_style}' id='sent-tran-b{$book}-{$currParNo}-{$FetchText[$i]["begin"]}-{$i}' class='sent_trans ' book='$book' para='$currParNo' begin='{$FetchText[$i]["begin"]}'>".$tran_text;
  587. if($_view!="sent" && $_display=="sent"){
  588. echo "<span class='sent_count'>$sent_count</span>";
  589. }
  590. echo "</sent_trans>";
  591. echo "<script>";
  592. if($_display=="sent"){
  593. echo "document.getElementById('sent-translate-b{$book}-{$currParNo}-{$FetchText[$i]["begin"]}').appendChild(document.getElementById('sent-tran-b{$book}-{$currParNo}-{$FetchText[$i]["begin"]}-{$i}'));";
  594. }
  595. else{
  596. echo "document.getElementById('par-translate-b{$book}-{$currParNo}').appendChild(document.getElementById('sent-tran-b{$book}-{$currParNo}-{$FetchText[$i]["begin"]}-{$i}'));";
  597. }
  598. echo "</script>";
  599. }
  600. }
  601. }
  602. }
  603. //查询句子译文内容
  604. //查询句子译文内容结束
  605. echo "<div id='para_nav'>";
  606. echo "<div style='display:inline-flex;'>";
  607. echo "<svg t='1598094361320' class='icon' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='4933' width='32' height='32'><path d='M698.75712 684.4416a81.92 81.92 0 0 1-124.88704 106.06592l-191.488-225.4848a81.89952 81.89952 0 0 1 0-106.06592l191.488-225.4848a81.92 81.92 0 0 1 124.88704 106.06592l-146.45248 172.46208 146.45248 172.4416z' p-id='4934' fill='#757AF7'></path></svg>";
  608. echo "$prev_para_link</div>";
  609. echo "<div style='display:inline-flex;'>$next_para_link";
  610. echo "<svg t='1598094021808' class='icon' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='4451' width='32' height='32'><path d='M698.75712 565.02272l-191.488 225.4848a81.73568 81.73568 0 0 1-62.48448 28.89728 81.89952 81.89952 0 0 1-62.40256-134.94272l146.432-172.4416-146.432-172.4416a81.92 81.92 0 0 1 124.88704-106.06592l191.488 225.4848a81.87904 81.87904 0 0 1 0 106.02496z' p-id='4452' fill='#757AF7'></path></svg>";
  611. echo "</div>";
  612. echo "</div>";
  613. }
  614. ?>
  615. </div><!--main_text_view end-->
  616. <div id="new_comm_shell" style="display:none;">
  617. <div id="new_comm_div">
  618. <textarea id="new_comm_text"></textarea>
  619. <button onclick="new_comm_submit()">提交</button><button onclick="new_comm_cancel()">取消</button>
  620. </div>
  621. </div>
  622. <div id="dighest_edit_div" class="full_screen_window">
  623. <div class="win_caption">
  624. <div><button onclick="dighest_edit_cancle()">取消</button></div>
  625. <div><button onclick="dighest_edit_submit()">提交</button></div>
  626. </div>
  627. <div id="dighest_edit_body" class="win_body">
  628. <div>
  629. 标题:<input id="dighest_edit_title" />
  630. </div>
  631. <div>
  632. 简介:<textarea id="dighest_edit_summary"></textarea>
  633. </div>
  634. <div>
  635. 标签:<input id="dighest_edit_taget" />
  636. </div>
  637. <div id="dighest_text_preview">
  638. </div>
  639. </div>
  640. </div>
  641. <div id="right_panal_toc" style="position: fixed;top:3em;width:17em;left: calc(100% - 17em);height:auto; min-height:30em;border-left: 1px solid gray; font-size: 80%;padding: 2em 0.5em;">
  642. <?php
  643. if($currLevel>=$tocMinLevel){
  644. echo $htmlToc2;
  645. }
  646. ?>
  647. </div>
  648. </div>
  649. <!-- 全屏 黑色背景 -->
  650. <div id="BV" class="blackscreen" onclick="setNaviVisibility()"></div>
  651. <!-- nav begin-->
  652. <div id="leftmenuinner" class="viewswitch_off">
  653. <div class="win_caption">
  654. <div><button id="left_menu_hide" onclick="setNaviVisibility()">返回</button></div>
  655. <div id="menubartoolbar_New">
  656. <ul class="common-tab">
  657. <li id="content_menu_li" class="common-tab_li_act" onclick="menuSelected_2(menu_toc,'content_menu_li')">目录</li>
  658. <li id="palicanon_menu_li" class="common-tab_li" onclick="menuSelected_2(menu_pali_cannon,'palicanon_menu_li')">批注</li>
  659. <li id="bookmark_menu_li" class="common-tab_li" onclick="menuSelected_2(menu_bookmark,'bookmark_menu_li')">书签</li>
  660. </ul>
  661. </div>
  662. </div>
  663. <div class='toc' id='leftmenuinnerinner' style="font-family: 'Noto Serif';">
  664. <!-- toc begin -->
  665. <div class="menu" id="menu_toc">
  666. <a name="_Content" ></a>
  667. <select name="menu" onchange="show_toc_level(this)" style="display:none;">
  668. <option value="1">1</option>
  669. <option value="2">2</option>
  670. <option value="3">3</option>
  671. <option value="4">4</option>
  672. <option value="5">5</option>
  673. <option value="6">6</option>
  674. <option value="7">7</option>
  675. </select>
  676. <div id="toc_content"><?php echo $tocHtml; ?></div>
  677. </div>
  678. <!-- toc end -->
  679. <!-- comments begin -->
  680. <div class="menu" id="menu_comments">
  681. <div id="navi_comments_inner"></div>
  682. </div>
  683. <!-- comments end -->
  684. <!-- book mark begin -->
  685. <div class="menu" id="menu_bookmark" style="display:none;">
  686. <div>
  687. <input id="B_Bookmark_All" onclick="setBookmarkVisibility('all')" type="checkbox" style="width: 20px; height: 20px" />
  688. <input id="B_Bookmark_A" onclick="setBookmarkVisibility('bma','B_Bookmark_A')" type="checkbox" style="width: 20px; height: 20px" /><span class="bookmarkcolora , bookmarkcolorblock" >a</span>
  689. <input id="B_Bookmark_X" onclick="setBookmarkVisibility('bmx','B_Bookmark_X')" type="checkbox" style="width: 20px; height: 20px" checked /><span class="bookmarkcolorx , bookmarkcolorblock" >?</span>
  690. <input id="B_Bookmark_1" onclick="setBookmarkVisibility('bm1','B_Bookmark_1')" type="checkbox" style="width: 20px; height: 20px" checked /><span class="bookmarkcolor1 , bookmarkcolorblock" >1</span>
  691. <input id="B_Bookmark_2" onclick="setBookmarkVisibility('bm2','B_Bookmark_2')" type="checkbox" style="width: 20px; height: 20px" checked /><span class="bookmarkcolor2 , bookmarkcolorblock" >2</span>
  692. <input id="B_Bookmark_3" onclick="setBookmarkVisibility('bm3','B_Bookmark_3')" type="checkbox" style="width: 20px; height: 20px" checked /><span class="bookmarkcolor3 , bookmarkcolorblock" >3</span>
  693. <input id="B_Bookmark_4" onclick="setBookmarkVisibility('bm4','B_Bookmark_4')" type="checkbox" style="width: 20px; height: 20px" checked /><span class="bookmarkcolor4 , bookmarkcolorblock" >4</span>
  694. <input id="B_Bookmark_5" onclick="setBookmarkVisibility('bm5','B_Bookmark_5')" type="checkbox" style="width: 20px; height: 20px" checked /><span class="bookmarkcolor5 , bookmarkcolorblock" >5</span>
  695. <input id="B_Bookmark_0" onclick="setBookmarkVisibility('bm0','B_Bookmark_0')" type="checkbox" style="width: 20px; height: 20px" checked /><span class="bookmarkcolor0 , bookmarkcolorblock" >0</span>
  696. </div>
  697. <div id="navi_bookmark_inner"></div>
  698. </div>
  699. <!-- book mark end -->
  700. </div>
  701. </div>
  702. <!-- nav end -->
  703. </div>
  704. <div id="mean_menu" ></div>
  705. <script>
  706. //lookup();
  707. $(".pali").mouseover(function(e){
  708. var targ
  709. if (!e) var e = window.event;
  710. if (e.target) targ = e.target;
  711. else if (e.srcElement) targ = e.srcElement;
  712. if (targ.nodeType == 3) // defeat Safari bug
  713. targ = targ.parentNode;
  714. var pali_word;
  715. pali_word=targ.innerHTML;
  716. objCurrMouseOverPaliMean=targ.nextSibling;
  717. $("#tool_bar_title").html(pali_word);
  718. $("#mean_menu").html(getWordMeanMenu(pali_word));
  719. targ.parentNode.appendChild(document.getElementById("mean_menu"));
  720. });
  721. $("sent").click(function(e){
  722. let book = $(this).attr("book");
  723. let para = $(this).attr("para");
  724. let begin = $(this).attr("begin");
  725. let end = $(this).attr("end");
  726. window.location.assign("reader.php?view=sent&book="+book+"&para="+para+"&begin="+begin+"&end="+end);
  727. });
  728. $("sent").mouseenter(function(e){
  729. let book = $(this).attr("book");
  730. let para = $(this).attr("para");
  731. let begin = $(this).attr("begin");
  732. $(this).css("background-color","#fefec1");
  733. $("sent_trans[book='"+book+"'][para='"+para+"'][begin='"+begin+"']").css("background-color","#fefec1");
  734. });
  735. $("sent").mouseleave(function(e){
  736. let book = $(this).attr("book");
  737. let para = $(this).attr("para");
  738. let begin = $(this).attr("begin");
  739. $(this).css("background-color","unset");
  740. $("sent_trans[book='"+book+"'][para='"+para+"'][begin='"+begin+"']").css("background-color","unset");
  741. });
  742. $("para").mouseenter(function(e){
  743. let book = $(this).attr("book");
  744. let para = $(this).attr("para");
  745. $("sent[book='"+book+"'][para='"+para+"']").css("background-color","#fefec1");
  746. });
  747. $("para").mouseleave(function(e){
  748. let book = $(this).attr("book");
  749. let para = $(this).attr("para");
  750. $("sent[book='"+book+"'][para='"+para+"']").css("background-color","unset");
  751. });
  752. $("sent_trans").mouseenter(function(e){
  753. let book = $(this).attr("book");
  754. let para = $(this).attr("para");
  755. let begin = $(this).attr("begin");
  756. $(this).css("background-color","#fefec1");
  757. $("sent[book='"+book+"'][para='"+para+"'][begin='"+begin+"']").css("background-color","#fefec1");
  758. });
  759. $("sent_trans").mouseleave(function(e){
  760. let book = $(this).attr("book");
  761. let para = $(this).attr("para");
  762. let begin = $(this).attr("begin");
  763. $(this).css("background-color","unset");
  764. $("sent[book='"+book+"'][para='"+para+"'][begin='"+begin+"']").css("background-color","unset");
  765. });
  766. $("para").click(function(e){
  767. let book = $(this).attr("book");
  768. let para = $(this).attr("para");
  769. window.location.assign("reader.php?view=para&book="+book+"&para="+para);
  770. });
  771. term_updata_translation();
  772. var wordlist = new Array();
  773. $("term").each(function(index,element){
  774. wordlist.push($(this).attr("pali"));
  775. }
  776. );
  777. function haha(){
  778. var wordquery ="('" + wordlist.join("','")+"')";
  779. $.post("../term/term.php",
  780. {
  781. op:"extract",
  782. words:wordquery
  783. },
  784. function(data,status){
  785. if(data.length>0){
  786. try{
  787. arrMyTerm = JSON.parse(data);
  788. term_updata_translation();
  789. }
  790. catch(e){
  791. console.error(e.error+" data:"+data);
  792. }
  793. }
  794. });
  795. }
  796. </script>
  797. </body>
  798. </html>