note.js 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830
  1. var _display = "";
  2. var _word = "";
  3. var _channal = "";
  4. var _lang = "";
  5. var _author = "";
  6. var _arrData = new Array();
  7. var _channalData;
  8. var MAX_NOTE_NEST = 2;
  9. /*
  10. {{203-1654-23-45@11@en@*}}
  11. <note>203-1654-23-45@11@en@*</note>
  12. <note id=guid book=203 para=1654 begin=23 end=45 author=11 lang=en tag=*></note>
  13. <note id=guid book=203 para=1654 begin=23 end=45 author=11 lang=en tag=*>
  14. <div class=text>
  15. pali text
  16. </div>
  17. <tran>
  18. </tran>
  19. <ref>
  20. </ref>
  21. </note>
  22. */
  23. /*
  24. 解析百科字符串
  25. {{203-1654-23-45@11@en@*}}
  26. <note id=12345 info="203-1654-23-45@11@en@*"><note>
  27. <note id="guid" book=203 para=1654 begin=23 end=45 author=11 lang=en tag=*></note>
  28. */
  29. function note_create() {
  30. wbw_channal_list_init();
  31. note_sent_edit_dlg_init();
  32. term_edit_dlg_init();
  33. }
  34. function note_sent_edit_dlg_init() {
  35. $("body").append(
  36. '<div id="note_sent_edit_dlg" title="' + gLocal.gui.edit + '"><div id="edit_dialog_content"></div></div>'
  37. );
  38. $("#note_sent_edit_dlg").dialog({
  39. autoOpen: false,
  40. width: 550,
  41. buttons: [
  42. {
  43. text: gLocal.gui.save,
  44. click: function () {
  45. note_sent_save();
  46. $(this).dialog("close");
  47. },
  48. },
  49. {
  50. text: gLocal.gui.cancel,
  51. click: function () {
  52. $(this).dialog("close");
  53. },
  54. },
  55. ],
  56. });
  57. }
  58. function note_init(input) {
  59. let newString = input.replace(/\{\{/g, '<note info="');
  60. newString = newString.replace(/\}\}/g, '" ></note>');
  61. let output = "<div>";
  62. output += marked(newString);
  63. output += "</div>";
  64. return output;
  65. }
  66. function note_update_background_style() {
  67. var mSentsBook = new Array();
  68. var mBgIndex = 1;
  69. $("note[info]").each(function () {
  70. let info = $(this).attr("info").split("-");
  71. if (info.length >= 2) {
  72. let book = info[0];
  73. $(this).attr("book", book);
  74. if (!mSentsBook[book]) {
  75. mSentsBook[book] = mBgIndex;
  76. mBgIndex++;
  77. }
  78. $(this).addClass("bg_color_" + mSentsBook[book]);
  79. }
  80. });
  81. }
  82. //
  83. function note_refresh_new() {
  84. note_update_background_style();
  85. let objNotes = document.querySelectorAll("note");
  86. let arrSentInfo = new Array();
  87. for (const iterator of objNotes) {
  88. let id = iterator.id;
  89. if (id == null || id == "") {
  90. //查看这个节点是第几层note嵌套。大于预定层数退出。
  91. let layout = 1;
  92. let parent = iterator.parentNode;
  93. while (parent.nodeType == 1) {
  94. if (parent.nodeName == "NOTE") {
  95. layout++;
  96. if (layout > MAX_NOTE_NEST) {
  97. return false;
  98. }
  99. } else if (parent.nodeName == "BODY") {
  100. break;
  101. }
  102. parent = parent.parentNode;
  103. }
  104. id = com_guid();
  105. iterator.id = id;
  106. if (iterator.hasAttribute("info")) {
  107. let info = iterator.getAttribute("info");
  108. if (info != null || info != "") {
  109. /*
  110. let arrInfo = info.split("-");
  111. if (arrInfo.length >= 2) {
  112. let book = arrInfo[0];
  113. let para = arrInfo[1];
  114. }
  115. */
  116. arrSentInfo.push({ id: id, data: info });
  117. }
  118. }
  119. }
  120. }
  121. if (arrSentInfo.length > 0) {
  122. let setting = new Object();
  123. setting.lang = "";
  124. setting.channal = _channal;
  125. $.post(
  126. "../term/note.php",
  127. {
  128. setting: JSON.stringify(setting),
  129. data: JSON.stringify(arrSentInfo),
  130. },
  131. function (data, status) {
  132. if (status == "success") {
  133. try {
  134. let sentData = JSON.parse(data);
  135. for (const iterator of sentData) {
  136. let id = iterator.id;
  137. let strHtml = "<a name='" + id + "'></a>";
  138. if (_display && _display == "para") {
  139. //段落模式
  140. let strPalitext =
  141. "<pali book='" +
  142. iterator.book +
  143. "' para='" +
  144. iterator.para +
  145. "' begin='" +
  146. iterator.begin +
  147. "' end='" +
  148. iterator.end +
  149. "' >" +
  150. iterator.palitext +
  151. "</pali>";
  152. let divPali = $("#" + id)
  153. .parent()
  154. .children(".palitext");
  155. if (divPali.length == 0) {
  156. if (_channal != "") {
  157. let arrChannal = _channal.split(",");
  158. for (let index = arrChannal.length - 1; index >= 0; index--) {
  159. const iChannal = arrChannal[index];
  160. $("#" + id)
  161. .parent()
  162. .prepend("<div class='tran_div' channal='" + iChannal + "'></div>");
  163. }
  164. }
  165. $("#" + id)
  166. .parent()
  167. .prepend("<div class='palitext'></div>");
  168. }
  169. $("#" + id)
  170. .parent()
  171. .children(".palitext")
  172. .first()
  173. .append(strPalitext);
  174. let htmlTran = "";
  175. for (const oneTran of iterator.translation) {
  176. let html =
  177. "<span class='tran' lang='" +
  178. oneTran.lang +
  179. "' channal='" +
  180. oneTran.channal +
  181. "'>";
  182. html += marked(
  183. term_std_str_to_tran(
  184. oneTran.text,
  185. oneTran.channal,
  186. oneTran.editor,
  187. oneTran.lang
  188. )
  189. );
  190. html += "</span>";
  191. if (_channal == "") {
  192. htmlTran += html;
  193. } else {
  194. $("#" + id)
  195. .siblings(".tran_div[channal='" + oneTran.channal + "']")
  196. .append(html);
  197. }
  198. }
  199. $("#" + id).html(htmlTran);
  200. } else {
  201. //句子模式
  202. strHtml += note_json_html(iterator);
  203. $("#" + id).html(strHtml);
  204. }
  205. }
  206. //处理<code>标签作为气泡注释
  207. popup_init();
  208. //刷新句子链接递归,有加层数限制。
  209. note_refresh_new();
  210. _arrData = _arrData.concat(sentData);
  211. note_ref_init();
  212. term_get_dict();
  213. note_channal_list();
  214. } catch (e) {
  215. console.error(e);
  216. }
  217. }
  218. }
  219. );
  220. } else {
  221. //term_get_dict();
  222. }
  223. }
  224. //生成channel列表
  225. function note_channal_list() {
  226. console.log("note_channal_list start");
  227. let arrSentInfo = new Array();
  228. $("note").each(function () {
  229. let info = $(this).attr("info");
  230. if (info && info != "") {
  231. arrSentInfo.push({ id: "", data: info });
  232. }
  233. });
  234. if (arrSentInfo.length > 0) {
  235. $.post(
  236. "../term/channal_list.php",
  237. {
  238. setting: "",
  239. data: JSON.stringify(arrSentInfo),
  240. },
  241. function (data, status) {
  242. if (status == "success") {
  243. try {
  244. let active = JSON.parse(data);
  245. _channalData = active;
  246. for (const iterator of _my_channal) {
  247. let found = false;
  248. for (const one of active) {
  249. if (iterator.id == one.id) {
  250. found = true;
  251. break;
  252. }
  253. }
  254. if (found == false) {
  255. _channalData.push(iterator);
  256. }
  257. }
  258. let strHtml = "";
  259. for (const iterator of _channalData) {
  260. if (_channal.indexOf(iterator.id) >= 0) {
  261. strHtml += render_channal_list(iterator);
  262. }
  263. }
  264. for (const iterator of _channalData) {
  265. if (_channal.indexOf(iterator.id) == -1) {
  266. strHtml += render_channal_list(iterator);
  267. }
  268. }
  269. $("#channal_list").html(strHtml);
  270. set_more_button_display();
  271. } catch (e) {
  272. console.error(e);
  273. }
  274. }
  275. }
  276. );
  277. }
  278. }
  279. function find_channal(id) {
  280. for (const iterator of _channalData) {
  281. if (id == iterator.id) {
  282. return iterator;
  283. }
  284. }
  285. return false;
  286. }
  287. function render_channal_list(channalinfo) {
  288. let output = "";
  289. let checked = "";
  290. let selected = "noselect";
  291. if (_channal.indexOf(channalinfo.id) >= 0) {
  292. checked = "checked";
  293. selected = "selected";
  294. }
  295. output += "<div class='list_with_head " + selected + "'>";
  296. output +=
  297. '<div class="channel_select"><input type="checkbox" ' + checked + " channal_id='" + channalinfo.id + "'></div>";
  298. output += "<div class='head'>";
  299. output += "<span class='head_img'>";
  300. output += channalinfo.nickname.slice(0, 2);
  301. output += "</span>";
  302. output += "</div>";
  303. output += "<div style='width: 100%;overflow-x: hidden;'>";
  304. output += "<div class='channal_list' >";
  305. // output += "<a href='../wiki/wiki.php?word=" + _word;
  306. // output += "&channal=" + channalinfo.id + "' >";
  307. output += "<a onclick=\"set_channal('" + channalinfo.id + "')\">";
  308. output += channalinfo["name"];
  309. output += "</a>";
  310. output += "@" + channalinfo["nickname"];
  311. output += "</div>";
  312. output += "<div class='userinfo_channal'>";
  313. output += channalinfo["username"];
  314. output += "</div>";
  315. if (channalinfo["final"]) {
  316. //进度
  317. output += "<div>";
  318. let article_len = channalinfo["article_len"];
  319. let svg_width = article_len;
  320. let svg_height = parseInt(article_len / 10);
  321. output += '<svg viewBox="0 0 ' + svg_width + " " + svg_height + '" width="100%" >';
  322. let curr_x = 0;
  323. let allFinal = 0;
  324. for (const iterator of channalinfo["final"]) {
  325. let stroke_width = parseInt(iterator.len);
  326. output += "<rect ";
  327. output += ' x="' + curr_x + '"';
  328. output += ' y="0"';
  329. output += ' height="' + svg_height + '"';
  330. output += ' width="' + stroke_width + '"';
  331. if (iterator.final == true) {
  332. allFinal += stroke_width;
  333. output += ' class="progress_bar_done" ';
  334. } else {
  335. output += ' class="progress_bar_undone" ';
  336. }
  337. output += "/>";
  338. curr_x += stroke_width;
  339. }
  340. output +=
  341. "<rect x='0' y='0' width='" + svg_width + "' height='" + svg_height / 5 + "' class='progress_bar_bg' />";
  342. output +=
  343. "<rect x='0' y='0' width='" +
  344. allFinal +
  345. "' height='" +
  346. svg_height / 5 +
  347. "' class='progress_bar_percent' style='stroke-width: 0; fill: rgb(100, 228, 100);'/>";
  348. output += '<text x="0" y="' + svg_height + '" font-size="' + svg_height * 0.8 + '">';
  349. output += channalinfo["count"] + "/" + channalinfo["all"];
  350. output += "</text>";
  351. output += "<svg>";
  352. output += "</div>";
  353. //进度结束
  354. }
  355. output += "</div>";
  356. output += "</div>";
  357. return output;
  358. }
  359. function onChannelMultiSelectStart() {
  360. $(".channel_select").show();
  361. }
  362. function onChannelMultiSelectCancel() {
  363. $(".channel_select").hide();
  364. }
  365. function onChannelChange() {
  366. let channal_list = new Array();
  367. $("[channal_id]").each(function () {
  368. if (this.checked) {
  369. channal_list.push($(this).attr("channal_id"));
  370. }
  371. });
  372. set_channal(channal_list.join());
  373. }
  374. //点击引用 需要响应的事件
  375. function note_ref_init() {
  376. $("chapter").click(function () {
  377. let bookid = $(this).attr("book");
  378. let para = $(this).attr("para");
  379. window.open("../reader/?view=chapter&book=" + bookid + "&para=" + para, "_blank");
  380. });
  381. $("para").click(function () {
  382. let bookid = $(this).attr("book");
  383. let para = $(this).attr("para");
  384. window.open("../reader/?view=para&book=" + bookid + "&para=" + para, "_blank");
  385. });
  386. }
  387. /*
  388. id
  389. palitext
  390. tran
  391. ref
  392. */
  393. function note_json_html(in_json) {
  394. let output = "";
  395. output += '<div class="note_tool_bar" style=" position: relative;">';
  396. output += '<div class="case_dropdown note_tool_context" >';
  397. output += "<svg class='icon' >";
  398. output += "<use xlink:href='../studio/svg/icon.svg#ic_more'></use>";
  399. output += "</svg>";
  400. output += "<div class='case_dropdown-content sent_menu'>";
  401. if (typeof _reader_view != "undefined" && _reader_view != "sent") {
  402. output += "<a onclick='junp_to(this)'>跳转至此句</a>";
  403. }
  404. output +=
  405. "<a onclick=\"copy_ref('" +
  406. in_json.book +
  407. "','" +
  408. in_json.para +
  409. "','" +
  410. in_json.begin +
  411. "','" +
  412. in_json.end +
  413. "')\">" +
  414. gLocal.gui.copy_link +
  415. "</a>";
  416. output += "<a onclick='copy_text(this)'>" + gLocal.gui.copy + "“" + gLocal.gui.pāli + "”</a>";
  417. output +=
  418. "<a onclick=\"edit_in_studio('" +
  419. in_json.book +
  420. "','" +
  421. in_json.para +
  422. "','" +
  423. in_json.begin +
  424. "','" +
  425. in_json.end +
  426. "')\">" +
  427. gLocal.gui.edit_now +
  428. "</a>";
  429. output += "<a onclick='add_to_list()'>" + gLocal.gui.add_to_edit_list + "</a>";
  430. output += "</div>";
  431. output += "</div>";
  432. output += " </div>";
  433. output += "<div class='palitext'>" + in_json.palitext + "</div>";
  434. //output += "<div class='translation_div'>";
  435. for (const iterator of in_json.translation) {
  436. output += "<div class='tran' lang='" + iterator.lang + "'>";
  437. //译文工具按钮开始
  438. output += "<div class='tran_text_tool_botton' onclick='tool_bar_show(this)'>";
  439. output +=
  440. "<div class='icon_expand' style='width: 0.8em;height: 0.8em;min-width: 0.8em;min-height: 0.8em;transition: transform 0.5s ease;'></div>";
  441. //译文工具栏开始
  442. output += "<div class='tran_text_tool_bar'>";
  443. output += "<div style='border-right: solid 1px;margin: 0.3em 0;'><li class = 'tip_buttom' ";
  444. output +=
  445. " onclick=\"note_edit_sentence('" +
  446. in_json.book +
  447. "' ,'" +
  448. in_json.para +
  449. "' ,'" +
  450. in_json.begin +
  451. "' ,'" +
  452. in_json.end +
  453. "' ,'" +
  454. iterator.channal +
  455. "')\"";
  456. output +=
  457. ">" +
  458. '<svg class="icon" ><use xlink="http://www.w3.org/1999/xlink" href="../studio/svg/icon.svg#ic_mode_edit"></use></svg>';
  459. output += gLocal.gui.edit + "</li>";
  460. output += "<li class = 'tip_buttom' ";
  461. output += " onclick=\"history_show('" + iterator.id + "')\"";
  462. output +=
  463. ">" +
  464. '<svg class="icon" ><use xlink="http://www.w3.org/1999/xlink" href="../studio/svg/icon.svg#recent_scan"></use></svg>';
  465. output += gLocal.gui.timeline + "</li>";
  466. output +=
  467. "<li class = 'tip_buttom'>" +
  468. '<svg class="icon" ><use xlink="http://www.w3.org/1999/xlink" href="../studio/svg/icon.svg#copy"></use></svg>';
  469. output += gLocal.gui.copy + "</li></div>";
  470. output +=
  471. "<div style='border-right: solid 1px;margin: 0.3em 0;'><li class = 'tip_buttom'>" +
  472. '<svg class="icon" ><use xlink="http://www.w3.org/1999/xlink" href="../studio/svg/icon.svg#like"></use></svg>';
  473. output += gLocal.gui.like + "</li>";
  474. output +=
  475. "<li class = 'tip_buttom'>" +
  476. '<svg class="icon" ><use xlink="http://www.w3.org/1999/xlink" href="../studio/svg/icon.svg#comment"></use></svg>';
  477. output += gLocal.gui.comment + "</li>";
  478. output +=
  479. "<li class = 'tip_buttom'>" +
  480. '<svg class="icon" ><use xlink="http://www.w3.org/1999/xlink" href="../studio/svg/icon.svg#ic_shopping_cart"></use></svg>';
  481. output += gLocal.gui.digest + "</li></div>";
  482. output +=
  483. "<div style='margin: 0.3em 0;'><li class = 'tip_buttom'>" +
  484. '<svg class="icon" ><use xlink="http://www.w3.org/1999/xlink" href="../studio/svg/icon.svg#share_to"></use></svg>';
  485. output += gLocal.gui.share_to + "</li>";
  486. output += "</div></div>";
  487. //译文工具栏结束
  488. output += "</div>";
  489. //译文工具按钮结束
  490. //译文正文开始
  491. output +=
  492. "<div class='text' id='tran_text_" +
  493. in_json.book +
  494. "_" +
  495. in_json.para +
  496. "_" +
  497. in_json.begin +
  498. "_" +
  499. in_json.end +
  500. "_" +
  501. iterator.channal +
  502. "'>";
  503. if (iterator.text == "") {
  504. output +=
  505. "<span style='color:var(--border-line-color);'>" +
  506. iterator.channalinfo.name +
  507. "-" +
  508. iterator.channalinfo.lang +
  509. "</span>";
  510. } else {
  511. //note_init处理句子链接 marked不处理
  512. //output += marked(term_std_str_to_tran(iterator.text, iterator.channal, iterator.editor, iterator.lang));
  513. output += note_init(term_std_str_to_tran(iterator.text, iterator.channal, iterator.editor, iterator.lang));
  514. }
  515. output += "</div>";
  516. //译文正文结束
  517. output += "</div>";
  518. //单个channal译文框结束
  519. }
  520. //所选全部译文结束
  521. //output += "</div>";
  522. //未选择的其他译文开始
  523. output += "<div class='other_tran_div' sent='";
  524. output += in_json.book + "-" + in_json.para + "-" + in_json.begin + "-" + in_json.end;
  525. output += "'>";
  526. output += "<div class='tool_bar'>";
  527. output += "<span class='more_tran icon_expand'></span>";
  528. output += "<span class='other_tran_span'>" + gLocal.gui.other + gLocal.gui.translation + "</span>";
  529. output += "<span class='other_tran_num'></span>";
  530. output += "</div>";
  531. output += "<div class='other_tran'>";
  532. output += "</div>";
  533. output += "</div>";
  534. //未选择的其他译文开始
  535. //新增译文按钮开始
  536. output += "<div class='add_new icon_add' ";
  537. output += "book='" + in_json.book + "' ";
  538. output += "para='" + in_json.para + "' ";
  539. output += "begin='" + in_json.begin + "' ";
  540. output += "end='" + in_json.end + "' ";
  541. output += " >";
  542. //output += "<div class='more_tran icon_expand'></div>";
  543. output += "</div>";
  544. //新增译文按钮结束
  545. //出处路径开始
  546. output += "<div class='ref'>" + in_json.ref;
  547. output +=
  548. "<span class='sent_no'>" +
  549. in_json.book +
  550. "-" +
  551. in_json.para +
  552. "-" +
  553. in_json.begin +
  554. "-" +
  555. in_json.end +
  556. "<span>" +
  557. "</div>";
  558. //出处路径结束
  559. return output;
  560. }
  561. function set_more_button_display() {
  562. $(".other_tran_div").each(function () {
  563. const sentid = $(this).attr("sent").split("-");
  564. const book = sentid[0];
  565. const para = sentid[1];
  566. const begin = sentid[2];
  567. const end = sentid[3];
  568. let count = 0;
  569. for (const iterator of _channalData) {
  570. if (iterator.final) {
  571. for (const onesent of iterator.final) {
  572. let id = onesent.id.split("-");
  573. if (book == id[0] && para == id[1] && begin == id[2] && end == id[3] && onesent.final) {
  574. if (_channal.indexOf(iterator.id) == -1) {
  575. count++;
  576. }
  577. }
  578. }
  579. }
  580. }
  581. if (count > 0) {
  582. $(this).find(".other_tran_num").html(count);
  583. $(this).find(".other_tran_num").attr("style", "display:inline-flex;");
  584. $(this)
  585. .find(".tool_bar")
  586. .click(function () {
  587. const sentid = $(this).parent().attr("sent").split("-");
  588. const book = sentid[0];
  589. const para = sentid[1];
  590. const begin = sentid[2];
  591. const end = sentid[3];
  592. let sentId = book + "-" + para + "-" + begin + "-" + end;
  593. if ($(this).siblings(".other_tran").first().css("display") == "none") {
  594. $(".other_tran_div[sent='" + sentId + "']")
  595. .children(".other_tran")
  596. .slideDown();
  597. $(this).children(".more_tran ").css("transform", "unset");
  598. $.get(
  599. "../usent/get.php",
  600. {
  601. book: book,
  602. para: para,
  603. begin: begin,
  604. end: end,
  605. },
  606. function (data, status) {
  607. let arrSent = JSON.parse(data);
  608. let html = "";
  609. for (const iterator of arrSent) {
  610. if (_channal.indexOf(iterator.channal) == -1) {
  611. html += "<div>" + marked(iterator.text) + "</div>";
  612. }
  613. }
  614. let sentId =
  615. arrSent[0].book +
  616. "-" +
  617. arrSent[0].paragraph +
  618. "-" +
  619. arrSent[0].begin +
  620. "-" +
  621. arrSent[0].end;
  622. $(".other_tran_div[sent='" + sentId + "']")
  623. .children(".other_tran")
  624. .html(html);
  625. }
  626. );
  627. } else {
  628. $(".other_tran_div[sent='" + sentId + "']")
  629. .children(".other_tran")
  630. .slideUp();
  631. $(this).children(".more_tran ").css("transform", "rotate(-90deg)");
  632. }
  633. });
  634. } else {
  635. //隐藏自己
  636. //$(this).hide();
  637. $(this)
  638. .find(".other_tran_span")
  639. .html(gLocal.gui.no + gLocal.gui.other + gLocal.gui.translation);
  640. $(this).find(".more_tran").hide();
  641. }
  642. });
  643. }
  644. function note_edit_sentence(book, para, begin, end, channal) {
  645. let channalInfo;
  646. for (const iterator of _channalData) {
  647. if (iterator.id == channal) {
  648. channalInfo = iterator;
  649. break;
  650. }
  651. }
  652. for (const iterator of _arrData) {
  653. if (iterator.book == book && iterator.para == para && iterator.begin == begin && iterator.end == end) {
  654. for (const tran of iterator.translation) {
  655. if (tran.channal == channal) {
  656. let html = "";
  657. html += "<div style='color:blue;'>" + channalInfo.name + "@" + channalInfo.nickname + "</div>";
  658. html +=
  659. "<textarea id='edit_dialog_text' sent_id='" +
  660. tran.id +
  661. "' book='" +
  662. iterator.book +
  663. "' para='" +
  664. iterator.para +
  665. "' begin='" +
  666. iterator.begin +
  667. "' end='" +
  668. iterator.end +
  669. "' channal='" +
  670. tran.channal +
  671. "' style='width:100%;min-height:260px;'>" +
  672. tran.text +
  673. "</textarea>";
  674. $("#edit_dialog_content").html(html);
  675. $("#note_sent_edit_dlg").dialog("open");
  676. return;
  677. }
  678. }
  679. }
  680. }
  681. alert("未找到句子");
  682. }
  683. function note_sent_save() {
  684. let id = $("#edit_dialog_text").attr("sent_id");
  685. let book = $("#edit_dialog_text").attr("book");
  686. let para = $("#edit_dialog_text").attr("para");
  687. let begin = $("#edit_dialog_text").attr("begin");
  688. let end = $("#edit_dialog_text").attr("end");
  689. let channal = $("#edit_dialog_text").attr("channal");
  690. let text = $("#edit_dialog_text").val();
  691. $.post(
  692. "../usent/sent_post.php",
  693. {
  694. id: id,
  695. book: book,
  696. para: para,
  697. begin: begin,
  698. end: end,
  699. channal: channal,
  700. text: text,
  701. lang: "zh",
  702. },
  703. function (data) {
  704. let result = JSON.parse(data);
  705. if (result.status > 0) {
  706. alert("error" + result.message);
  707. } else {
  708. ntf_show("success");
  709. if (result.text == "") {
  710. let channel_info = "Empty";
  711. let thisChannel = find_channal(result.channal);
  712. if (thisChannel) {
  713. channel_info = thisChannel.name + "-" + thisChannel.nickname;
  714. }
  715. $(
  716. "#tran_text_" +
  717. result.book +
  718. "_" +
  719. result.para +
  720. "_" +
  721. result.begin +
  722. "_" +
  723. result.end +
  724. "_" +
  725. result.channal
  726. ).html("<span style='color:var(--border-line-color);'>" + channel_info + "</span>");
  727. } else {
  728. $(
  729. "#tran_text_" +
  730. result.book +
  731. "_" +
  732. result.para +
  733. "_" +
  734. result.begin +
  735. "_" +
  736. result.end +
  737. "_" +
  738. result.channal
  739. ).html(marked(term_std_str_to_tran(result.text, result.channal, result.editor, result.lang)));
  740. term_updata_translation();
  741. for (const iterator of _arrData) {
  742. if (
  743. iterator.book == result.book &&
  744. iterator.para == result.para &&
  745. iterator.begin == result.begin &&
  746. iterator.end == result.end
  747. ) {
  748. for (const tran of iterator.translation) {
  749. if (tran.channal == result.channal) {
  750. tran.text = result.text;
  751. break;
  752. }
  753. }
  754. }
  755. }
  756. }
  757. }
  758. }
  759. );
  760. }
  761. function copy_ref(book, para, begin, end) {
  762. let strRef = "{{" + book + "-" + para + "-" + begin + "-" + end + "}}";
  763. copy_to_clipboard(strRef);
  764. }
  765. function edit_in_studio(book, para, begin, end) {
  766. wbw_channal_list_open(book, [para]);
  767. }
  768. function tool_bar_show(element) {
  769. if ($(element).find(".tran_text_tool_bar").css("display") == "none") {
  770. $(element).find(".tran_text_tool_bar").css("display", "flex");
  771. $(element).find(".icon_expand").css("transform", "rotate(-180deg)");
  772. $(element).css("background-color", "var(--btn-bg-color)");
  773. $(element).css("visibility", "visible");
  774. $(document).one("click", function () {
  775. $(element).find(".tran_text_tool_bar").hide();
  776. $(element).css("background-color", "var(--nocolor)");
  777. $(element).find(".icon_expand").css("transform", "unset");
  778. $(element).css("visibility", "");
  779. });
  780. event.stopPropagation();
  781. } else {
  782. $(element).find(".tran_text_tool_bar").hide();
  783. $(element).css("background-color", "var(--nocolor)");
  784. $(element).find(".icon_expand").css("transform", "unset");
  785. $(element).css("visibility", "");
  786. }
  787. }