pdf_outline_viewer.js 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276
  1. /**
  2. * @licstart The following is the entire license notice for the
  3. * Javascript code in this page
  4. *
  5. * Copyright 2019 Mozilla Foundation
  6. *
  7. * Licensed under the Apache License, Version 2.0 (the "License");
  8. * you may not use this file except in compliance with the License.
  9. * You may obtain a copy of the License at
  10. *
  11. * http://www.apache.org/licenses/LICENSE-2.0
  12. *
  13. * Unless required by applicable law or agreed to in writing, software
  14. * distributed under the License is distributed on an "AS IS" BASIS,
  15. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  16. * See the License for the specific language governing permissions and
  17. * limitations under the License.
  18. *
  19. * @licend The above is the entire license notice for the
  20. * Javascript code in this page
  21. */
  22. "use strict";
  23. Object.defineProperty(exports, "__esModule", {
  24. value: true
  25. });
  26. exports.PDFOutlineViewer = void 0;
  27. var _pdf = require("../pdf");
  28. function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
  29. function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
  30. function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
  31. var DEFAULT_TITLE = "\u2013";
  32. var PDFOutlineViewer =
  33. /*#__PURE__*/
  34. function () {
  35. function PDFOutlineViewer(_ref) {
  36. var container = _ref.container,
  37. linkService = _ref.linkService,
  38. eventBus = _ref.eventBus;
  39. _classCallCheck(this, PDFOutlineViewer);
  40. this.container = container;
  41. this.linkService = linkService;
  42. this.eventBus = eventBus;
  43. this.reset();
  44. eventBus.on('toggleoutlinetree', this.toggleOutlineTree.bind(this));
  45. }
  46. _createClass(PDFOutlineViewer, [{
  47. key: "reset",
  48. value: function reset() {
  49. this.outline = null;
  50. this.lastToggleIsShow = true;
  51. this.container.textContent = '';
  52. this.container.classList.remove('outlineWithDeepNesting');
  53. }
  54. }, {
  55. key: "_dispatchEvent",
  56. value: function _dispatchEvent(outlineCount) {
  57. this.eventBus.dispatch('outlineloaded', {
  58. source: this,
  59. outlineCount: outlineCount
  60. });
  61. }
  62. }, {
  63. key: "_bindLink",
  64. value: function _bindLink(element, _ref2) {
  65. var url = _ref2.url,
  66. newWindow = _ref2.newWindow,
  67. dest = _ref2.dest;
  68. var linkService = this.linkService;
  69. if (url) {
  70. (0, _pdf.addLinkAttributes)(element, {
  71. url: url,
  72. target: newWindow ? _pdf.LinkTarget.BLANK : linkService.externalLinkTarget,
  73. rel: linkService.externalLinkRel,
  74. enabled: linkService.externalLinkEnabled
  75. });
  76. return;
  77. }
  78. element.href = linkService.getDestinationHash(dest);
  79. element.onclick = function () {
  80. if (dest) {
  81. linkService.navigateTo(dest);
  82. }
  83. return false;
  84. };
  85. }
  86. }, {
  87. key: "_setStyles",
  88. value: function _setStyles(element, _ref3) {
  89. var bold = _ref3.bold,
  90. italic = _ref3.italic;
  91. var styleStr = '';
  92. if (bold) {
  93. styleStr += 'font-weight: bold;';
  94. }
  95. if (italic) {
  96. styleStr += 'font-style: italic;';
  97. }
  98. if (styleStr) {
  99. element.setAttribute('style', styleStr);
  100. }
  101. }
  102. }, {
  103. key: "_addToggleButton",
  104. value: function _addToggleButton(div, _ref4) {
  105. var _this = this;
  106. var count = _ref4.count,
  107. items = _ref4.items;
  108. var toggler = document.createElement('div');
  109. toggler.className = 'outlineItemToggler';
  110. if (count < 0 && Math.abs(count) === items.length) {
  111. toggler.classList.add('outlineItemsHidden');
  112. }
  113. toggler.onclick = function (evt) {
  114. evt.stopPropagation();
  115. toggler.classList.toggle('outlineItemsHidden');
  116. if (evt.shiftKey) {
  117. var shouldShowAll = !toggler.classList.contains('outlineItemsHidden');
  118. _this._toggleOutlineItem(div, shouldShowAll);
  119. }
  120. };
  121. div.insertBefore(toggler, div.firstChild);
  122. }
  123. }, {
  124. key: "_toggleOutlineItem",
  125. value: function _toggleOutlineItem(root) {
  126. var show = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
  127. this.lastToggleIsShow = show;
  128. var _iteratorNormalCompletion = true;
  129. var _didIteratorError = false;
  130. var _iteratorError = undefined;
  131. try {
  132. for (var _iterator = root.querySelectorAll('.outlineItemToggler')[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
  133. var toggler = _step.value;
  134. toggler.classList.toggle('outlineItemsHidden', !show);
  135. }
  136. } catch (err) {
  137. _didIteratorError = true;
  138. _iteratorError = err;
  139. } finally {
  140. try {
  141. if (!_iteratorNormalCompletion && _iterator["return"] != null) {
  142. _iterator["return"]();
  143. }
  144. } finally {
  145. if (_didIteratorError) {
  146. throw _iteratorError;
  147. }
  148. }
  149. }
  150. }
  151. }, {
  152. key: "toggleOutlineTree",
  153. value: function toggleOutlineTree() {
  154. if (!this.outline) {
  155. return;
  156. }
  157. this._toggleOutlineItem(this.container, !this.lastToggleIsShow);
  158. }
  159. }, {
  160. key: "render",
  161. value: function render(_ref5) {
  162. var outline = _ref5.outline;
  163. var outlineCount = 0;
  164. if (this.outline) {
  165. this.reset();
  166. }
  167. this.outline = outline || null;
  168. if (!outline) {
  169. this._dispatchEvent(outlineCount);
  170. return;
  171. }
  172. var fragment = document.createDocumentFragment();
  173. var queue = [{
  174. parent: fragment,
  175. items: this.outline
  176. }];
  177. var hasAnyNesting = false;
  178. while (queue.length > 0) {
  179. var levelData = queue.shift();
  180. var _iteratorNormalCompletion2 = true;
  181. var _didIteratorError2 = false;
  182. var _iteratorError2 = undefined;
  183. try {
  184. for (var _iterator2 = levelData.items[Symbol.iterator](), _step2; !(_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done); _iteratorNormalCompletion2 = true) {
  185. var item = _step2.value;
  186. var div = document.createElement('div');
  187. div.className = 'outlineItem';
  188. var element = document.createElement('a');
  189. this._bindLink(element, item);
  190. this._setStyles(element, item);
  191. element.textContent = (0, _pdf.removeNullCharacters)(item.title) || DEFAULT_TITLE;
  192. div.appendChild(element);
  193. if (item.items.length > 0) {
  194. hasAnyNesting = true;
  195. this._addToggleButton(div, item);
  196. var itemsDiv = document.createElement('div');
  197. itemsDiv.className = 'outlineItems';
  198. div.appendChild(itemsDiv);
  199. queue.push({
  200. parent: itemsDiv,
  201. items: item.items
  202. });
  203. }
  204. levelData.parent.appendChild(div);
  205. outlineCount++;
  206. }
  207. } catch (err) {
  208. _didIteratorError2 = true;
  209. _iteratorError2 = err;
  210. } finally {
  211. try {
  212. if (!_iteratorNormalCompletion2 && _iterator2["return"] != null) {
  213. _iterator2["return"]();
  214. }
  215. } finally {
  216. if (_didIteratorError2) {
  217. throw _iteratorError2;
  218. }
  219. }
  220. }
  221. }
  222. if (hasAnyNesting) {
  223. this.container.classList.add('outlineWithDeepNesting');
  224. this.lastToggleIsShow = fragment.querySelectorAll('.outlineItemsHidden').length === 0;
  225. }
  226. this.container.appendChild(fragment);
  227. this._dispatchEvent(outlineCount);
  228. }
  229. }]);
  230. return PDFOutlineViewer;
  231. }();
  232. exports.PDFOutlineViewer = PDFOutlineViewer;