@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.
- package/package.json +8 -2
- package/pdfjs/dist/event_utils.js +207 -0
- package/pdfjs/dist/genericl10n.js +2420 -0
- package/pdfjs/dist/message_handler.js +327 -192
- package/pdfjs/dist/node_stream.js +2 -494
- package/pdfjs/dist/node_stream2.js +1759 -0
- package/pdfjs/dist/pdf.js +17910 -9761
- package/pdfjs/dist/pdf.worker.js +24 -0
- package/pdfjs/dist/pdf_link_service.js +223 -378
- package/pdfjs/dist/pdf_rendering_queue.js +62 -62
- package/pdfjs/dist/pdf_thumbnail_viewer.js +216 -399
- package/pdfjs/dist/pdf_viewer.js +3450 -2305
- package/pdfjs/dist/ui_utils.js +209 -480
- package/pdfjs/dist/util.js +384 -595
- package/pdfjs/dist/worker.js +44555 -45401
- package/src/vcf-pdf-viewer.js +153 -16
- package/pdfjs/dist/display_utils.js +0 -848
- package/pdfjs/dist/fetch_stream.js +0 -306
- package/pdfjs/dist/l10n_utils.js +0 -140
- package/pdfjs/dist/network.js +0 -565
- package/pdfjs/dist/network_utils.js +0 -340
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import './pdf.js';
|
|
2
|
-
import {
|
|
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
|
-
|
|
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
|
-
}
|
|
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
|
-
|
|
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
|
-
}
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
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
|
-
}
|
|
138
|
-
const previousPageIndex = visible.first.id - 2;
|
|
137
|
+
}
|
|
139
138
|
|
|
140
|
-
|
|
141
|
-
|
|
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
|
-
}
|
|
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
|
|
199
|
+
export { PDFRenderingQueue };
|