@vaadin-component-factory/vcf-pdf-viewer 4.0.2 → 4.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,6 @@
1
1
  import './pdf.js';
2
- import { R as RenderingCancelledException } from './display_utils.js';
2
+ import { RenderingStates } from './ui_utils.js';
3
+ import { R as RenderingCancelledException } from './node_stream2.js';
3
4
  import './util.js';
4
5
  import './message_handler.js';
5
6
 
@@ -17,92 +18,85 @@ import './message_handler.js';
17
18
  * See the License for the specific language governing permissions and
18
19
  * limitations under the License.
19
20
  */
21
+
20
22
  const CLEANUP_TIMEOUT = 30000;
21
- const RenderingStates = {
22
- INITIAL: 0,
23
- RUNNING: 1,
24
- PAUSED: 2,
25
- FINISHED: 3
26
- };
23
+
27
24
  /**
28
25
  * Controls rendering of the views for pages and thumbnails.
29
26
  */
30
-
31
27
  class PDFRenderingQueue {
32
28
  constructor() {
33
29
  this.pdfViewer = null;
34
30
  this.pdfThumbnailViewer = null;
35
31
  this.onIdle = null;
36
32
  this.highestPriorityPage = null;
33
+ /** @type {number} */
37
34
  this.idleTimeout = null;
38
35
  this.printing = false;
39
36
  this.isThumbnailViewEnabled = false;
37
+ if (typeof PDFJSDev === "undefined" || PDFJSDev.test("GENERIC")) {
38
+ Object.defineProperty(this, "hasViewer", {
39
+ value: () => !!this.pdfViewer
40
+ });
41
+ }
40
42
  }
43
+
41
44
  /**
42
45
  * @param {PDFViewer} pdfViewer
43
46
  */
44
-
45
-
46
47
  setViewer(pdfViewer) {
47
48
  this.pdfViewer = pdfViewer;
48
49
  }
50
+
49
51
  /**
50
52
  * @param {PDFThumbnailViewer} pdfThumbnailViewer
51
53
  */
52
-
53
-
54
54
  setThumbnailViewer(pdfThumbnailViewer) {
55
55
  this.pdfThumbnailViewer = pdfThumbnailViewer;
56
56
  }
57
+
57
58
  /**
58
59
  * @param {IRenderableView} view
59
60
  * @returns {boolean}
60
61
  */
61
-
62
-
63
62
  isHighestPriority(view) {
64
63
  return this.highestPriorityPage === view.renderingId;
65
64
  }
65
+
66
66
  /**
67
67
  * @param {Object} currentlyVisiblePages
68
68
  */
69
-
70
-
71
69
  renderHighestPriority(currentlyVisiblePages) {
70
+ var _this$pdfThumbnailVie;
72
71
  if (this.idleTimeout) {
73
72
  clearTimeout(this.idleTimeout);
74
73
  this.idleTimeout = null;
75
- } // Pages have a higher priority than thumbnails, so check them first.
76
-
74
+ }
77
75
 
76
+ // Pages have a higher priority than thumbnails, so check them first.
78
77
  if (this.pdfViewer.forceRendering(currentlyVisiblePages)) {
79
78
  return;
80
- } // No pages needed rendering, so check thumbnails.
81
-
82
-
83
- if (this.pdfThumbnailViewer && this.isThumbnailViewEnabled) {
84
- if (this.pdfThumbnailViewer.forceRendering()) {
85
- return;
86
- }
87
79
  }
88
-
80
+ // No pages needed rendering, so check thumbnails.
81
+ if (this.isThumbnailViewEnabled && (_this$pdfThumbnailVie = this.pdfThumbnailViewer) !== null && _this$pdfThumbnailVie !== void 0 && _this$pdfThumbnailVie.forceRendering()) {
82
+ return;
83
+ }
89
84
  if (this.printing) {
90
85
  // If printing is currently ongoing do not reschedule cleanup.
91
86
  return;
92
87
  }
93
-
94
88
  if (this.onIdle) {
95
89
  this.idleTimeout = setTimeout(this.onIdle.bind(this), CLEANUP_TIMEOUT);
96
90
  }
97
91
  }
92
+
98
93
  /**
99
94
  * @param {Object} visible
100
95
  * @param {Array} views
101
96
  * @param {boolean} scrolledDown
97
+ * @param {boolean} [preRenderExtra]
102
98
  */
103
-
104
-
105
- getHighestPriority(visible, views, scrolledDown) {
99
+ getHighestPriority(visible, views, scrolledDown, preRenderExtra = false) {
106
100
  /**
107
101
  * The state has changed. Figure out which page has the highest priority to
108
102
  * render next (if any).
@@ -112,48 +106,62 @@ class PDFRenderingQueue {
112
106
  * 2. if last scrolled down, the page after the visible pages, or
113
107
  * if last scrolled up, the page before the visible pages
114
108
  */
115
- const visibleViews = visible.views;
116
- const numVisible = visibleViews.length;
117
-
109
+ const visibleViews = visible.views,
110
+ numVisible = visibleViews.length;
118
111
  if (numVisible === 0) {
119
112
  return null;
120
113
  }
121
-
122
- for (let i = 0; i < numVisible; ++i) {
114
+ for (let i = 0; i < numVisible; i++) {
123
115
  const view = visibleViews[i].view;
124
-
125
116
  if (!this.isViewFinished(view)) {
126
117
  return view;
127
118
  }
128
- } // All the visible views have rendered; try to render next/previous pages.
129
-
130
-
131
- if (scrolledDown) {
132
- const nextPageIndex = visible.last.id; // IDs start at 1, so no need to add 1.
133
-
134
- if (views[nextPageIndex] && !this.isViewFinished(views[nextPageIndex])) {
135
- return views[nextPageIndex];
119
+ }
120
+ const firstId = visible.first.id,
121
+ lastId = visible.last.id;
122
+
123
+ // All the visible views have rendered; try to handle any "holes" in the
124
+ // page layout (can happen e.g. with spreadModes at higher zoom levels).
125
+ if (lastId - firstId + 1 > numVisible) {
126
+ const visibleIds = visible.ids;
127
+ for (let i = 1, ii = lastId - firstId; i < ii; i++) {
128
+ const holeId = scrolledDown ? firstId + i : lastId - i;
129
+ if (visibleIds.has(holeId)) {
130
+ continue;
131
+ }
132
+ const holeView = views[holeId - 1];
133
+ if (!this.isViewFinished(holeView)) {
134
+ return holeView;
135
+ }
136
136
  }
137
- } else {
138
- const previousPageIndex = visible.first.id - 2;
137
+ }
139
138
 
140
- if (views[previousPageIndex] && !this.isViewFinished(views[previousPageIndex])) {
141
- return views[previousPageIndex];
139
+ // All the visible views have rendered; try to render next/previous page.
140
+ // (IDs start at 1, so no need to add 1 when `scrolledDown === true`.)
141
+ let preRenderIndex = scrolledDown ? lastId : firstId - 2;
142
+ let preRenderView = views[preRenderIndex];
143
+ if (preRenderView && !this.isViewFinished(preRenderView)) {
144
+ return preRenderView;
145
+ }
146
+ if (preRenderExtra) {
147
+ preRenderIndex += scrolledDown ? 1 : -1;
148
+ preRenderView = views[preRenderIndex];
149
+ if (preRenderView && !this.isViewFinished(preRenderView)) {
150
+ return preRenderView;
142
151
  }
143
- } // Everything that needs to be rendered has been.
144
-
145
-
152
+ }
153
+ // Everything that needs to be rendered has been.
146
154
  return null;
147
155
  }
156
+
148
157
  /**
149
158
  * @param {IRenderableView} view
150
159
  * @returns {boolean}
151
160
  */
152
-
153
-
154
161
  isViewFinished(view) {
155
162
  return view.renderingState === RenderingStates.FINISHED;
156
163
  }
164
+
157
165
  /**
158
166
  * Render a page or thumbnail view. This calls the appropriate function
159
167
  * based on the views state. If the view is already rendered it will return
@@ -161,22 +169,17 @@ class PDFRenderingQueue {
161
169
  *
162
170
  * @param {IRenderableView} view
163
171
  */
164
-
165
-
166
172
  renderView(view) {
167
173
  switch (view.renderingState) {
168
174
  case RenderingStates.FINISHED:
169
175
  return false;
170
-
171
176
  case RenderingStates.PAUSED:
172
177
  this.highestPriorityPage = view.renderingId;
173
178
  view.resume();
174
179
  break;
175
-
176
180
  case RenderingStates.RUNNING:
177
181
  this.highestPriorityPage = view.renderingId;
178
182
  break;
179
-
180
183
  case RenderingStates.INITIAL:
181
184
  this.highestPriorityPage = view.renderingId;
182
185
  view.draw().finally(() => {
@@ -185,15 +188,12 @@ class PDFRenderingQueue {
185
188
  if (reason instanceof RenderingCancelledException) {
186
189
  return;
187
190
  }
188
-
189
191
  console.error(`renderView: "${reason}"`);
190
192
  });
191
193
  break;
192
194
  }
193
-
194
195
  return true;
195
196
  }
196
-
197
197
  }
198
198
 
199
- export { PDFRenderingQueue, RenderingStates };
199
+ export { PDFRenderingQueue };