Merge pull request #3670 from Rob--W/mozPrintCallback-polyfill
Polyfill for mozPrintCallback
This commit is contained in:
commit
9db1e437b0
141
web/mozPrintCallback_polyfill.js
Normal file
141
web/mozPrintCallback_polyfill.js
Normal file
@ -0,0 +1,141 @@
|
||||
/* -*- Mode: Java; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
||||
/* vim: set shiftwidth=2 tabstop=2 autoindent cindent expandtab: */
|
||||
/* Copyright 2013 Mozilla Foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
/* globals HTMLCanvasElement */
|
||||
|
||||
'use strict';
|
||||
(function mozPrintCallbackPolyfillClosure() {
|
||||
if ('mozPrintCallback' in document.createElement('canvas')) {
|
||||
return;
|
||||
}
|
||||
// Cause positive result on feature-detection:
|
||||
HTMLCanvasElement.prototype.mozPrintCallback = undefined;
|
||||
|
||||
var canvases; // During print task: non-live NodeList of <canvas> elements
|
||||
var index; // Index of <canvas> element that is being processed
|
||||
|
||||
var print = window.print;
|
||||
window.print = function print() {
|
||||
if (canvases) {
|
||||
console.warn('Ignored window.print() because of a pending print job.');
|
||||
return;
|
||||
}
|
||||
try {
|
||||
dispatchEvent('beforeprint');
|
||||
} finally {
|
||||
canvases = document.querySelectorAll('canvas');
|
||||
index = -1;
|
||||
next();
|
||||
}
|
||||
};
|
||||
|
||||
function dispatchEvent(eventType) {
|
||||
var event = document.createEvent('CustomEvent');
|
||||
event.initCustomEvent(eventType, false, false, 'custom');
|
||||
window.dispatchEvent(event);
|
||||
}
|
||||
|
||||
function next() {
|
||||
if (!canvases) {
|
||||
return; // Print task cancelled by user (state reset in abort())
|
||||
}
|
||||
|
||||
renderProgress();
|
||||
if (++index < canvases.length) {
|
||||
var canvas = canvases[index];
|
||||
if (typeof canvas.mozPrintCallback === 'function') {
|
||||
canvas.mozPrintCallback({
|
||||
context: canvas.getContext('2d'),
|
||||
abort: abort,
|
||||
done: next
|
||||
});
|
||||
} else {
|
||||
next();
|
||||
}
|
||||
} else {
|
||||
renderProgress();
|
||||
print.call(window);
|
||||
setTimeout(abort, 20); // Tidy-up
|
||||
}
|
||||
}
|
||||
|
||||
function abort() {
|
||||
if (canvases) {
|
||||
canvases = null;
|
||||
renderProgress();
|
||||
dispatchEvent('afterprint');
|
||||
}
|
||||
}
|
||||
|
||||
function renderProgress() {
|
||||
var progressContainer = document.getElementById('mozPrintCallback-shim');
|
||||
if (canvases) {
|
||||
var progress = Math.round(100 * index / canvases.length);
|
||||
var progressBar = progressContainer.querySelector('progress');
|
||||
var progressPerc = progressContainer.querySelector('.relative-progress');
|
||||
progressBar.value = progress;
|
||||
progressPerc.textContent = progress + '%';
|
||||
progressContainer.removeAttribute('hidden');
|
||||
progressContainer.onclick = abort;
|
||||
} else {
|
||||
progressContainer.setAttribute('hidden', '');
|
||||
}
|
||||
}
|
||||
|
||||
var hasAttachEvent = !!document.attachEvent;
|
||||
|
||||
window.addEventListener('keydown', function(event) {
|
||||
if (event.keyCode === 80/*P*/ && (event.ctrlKey || event.metaKey)) {
|
||||
window.print();
|
||||
if (hasAttachEvent) {
|
||||
// Only attachEvent can cancel Ctrl + P dialog in IE <=10
|
||||
// attachEvent is gone in IE11, so the dialog will re-appear in IE11.
|
||||
return;
|
||||
}
|
||||
event.preventDefault();
|
||||
if (event.stopImmediatePropagation) {
|
||||
event.stopImmediatePropagation();
|
||||
} else {
|
||||
event.stopPropagation();
|
||||
}
|
||||
return;
|
||||
}
|
||||
if (event.keyCode === 27 && canvases) { // Esc
|
||||
abort();
|
||||
}
|
||||
}, true);
|
||||
if (hasAttachEvent) {
|
||||
document.attachEvent('onkeydown', function(event) {
|
||||
event = event || window.event;
|
||||
if (event.keyCode === 80/*P*/ && event.ctrlKey) {
|
||||
event.keyCode = 0;
|
||||
return false;
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
if ('onbeforeprint' in window) {
|
||||
// Do not propagate before/afterprint events when they are not triggered
|
||||
// from within this polyfill. (FF/IE).
|
||||
var stopPropagationIfNeeded = function(event) {
|
||||
if (event.detail !== 'custom' && event.stopImmediatePropagation) {
|
||||
event.stopImmediatePropagation();
|
||||
}
|
||||
};
|
||||
window.addEventListener('beforeprint', stopPropagationIfNeeded, false);
|
||||
window.addEventListener('afterprint', stopPropagationIfNeeded, false);
|
||||
}
|
||||
})();
|
@ -514,7 +514,7 @@ var PageView = function pageView(container, id, scale,
|
||||
// Use the same hack we use for high dpi displays for printing to get better
|
||||
// output until bug 811002 is fixed in FF.
|
||||
var PRINT_OUTPUT_SCALE = 2;
|
||||
var canvas = this.canvas = document.createElement('canvas');
|
||||
var canvas = document.createElement('canvas');
|
||||
canvas.width = Math.floor(viewport.width) * PRINT_OUTPUT_SCALE;
|
||||
canvas.height = Math.floor(viewport.height) * PRINT_OUTPUT_SCALE;
|
||||
canvas.style.width = (PRINT_OUTPUT_SCALE * viewport.width) + 'pt';
|
||||
@ -525,7 +525,11 @@ var PageView = function pageView(container, id, scale,
|
||||
CustomStyle.setProp('transformOrigin' , canvas, '0% 0%');
|
||||
|
||||
var printContainer = document.getElementById('printContainer');
|
||||
printContainer.appendChild(canvas);
|
||||
var canvasWrapper = document.createElement('div');
|
||||
canvasWrapper.style.width = viewport.width + 'pt';
|
||||
canvasWrapper.style.height = viewport.height + 'pt';
|
||||
canvasWrapper.appendChild(canvas);
|
||||
printContainer.appendChild(canvasWrapper);
|
||||
|
||||
var self = this;
|
||||
canvas.mozPrintCallback = function(obj) {
|
||||
|
71
web/viewer-snippet-mozPrintCallback-polyfill.html
Normal file
71
web/viewer-snippet-mozPrintCallback-polyfill.html
Normal file
@ -0,0 +1,71 @@
|
||||
<div id="mozPrintCallback-shim" hidden>
|
||||
<style scoped>
|
||||
#mozPrintCallback-shim {
|
||||
position: fixed;
|
||||
top: 0;
|
||||
left: 0;
|
||||
height: 100%;
|
||||
width: 100%;
|
||||
z-index: 9999999;
|
||||
|
||||
display: block;
|
||||
text-align: center;
|
||||
background-color: rgba(0, 0, 0, 0.5);
|
||||
}
|
||||
#mozPrintCallback-shim[hidden] {
|
||||
display: none;
|
||||
}
|
||||
@media print {
|
||||
#mozPrintCallback-shim {
|
||||
display: none;
|
||||
}
|
||||
}
|
||||
|
||||
#mozPrintCallback-shim .mozPrintCallback-dialog-box {
|
||||
display: inline-block;
|
||||
margin: -50px auto 0;
|
||||
position: relative;
|
||||
top: 45%;
|
||||
left: 0;
|
||||
min-width: 220px;
|
||||
max-width: 400px;
|
||||
|
||||
padding: 9px;
|
||||
|
||||
border: 1px solid hsla(0, 0%, 0%, .5);
|
||||
border-radius: 2px;
|
||||
box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
|
||||
|
||||
background-color: #474747;
|
||||
|
||||
color: hsl(0, 0%, 85%);
|
||||
font-size: 16px;
|
||||
line-height: 20px;
|
||||
}
|
||||
#mozPrintCallback-shim .progress-row {
|
||||
clear: both;
|
||||
padding: 1em 0;
|
||||
}
|
||||
#mozPrintCallback-shim progress {
|
||||
width: 100%;
|
||||
}
|
||||
#mozPrintCallback-shim .relative-progress {
|
||||
clear: both;
|
||||
float: right;
|
||||
}
|
||||
#mozPrintCallback-shim .progress-actions {
|
||||
clear: both;
|
||||
}
|
||||
</style>
|
||||
<div class="mozPrintCallback-dialog-box">
|
||||
<!-- TODO: Localise the following strings -->
|
||||
Preparing document for printing...
|
||||
<div class="progress-row">
|
||||
<progress value="0" max="100"></progress>
|
||||
<span class="relative-progress">0%</span>
|
||||
</div>
|
||||
<div class="progress-actions">
|
||||
<input type="button" value="Cancel" class="mozPrintCallback-cancel">
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
@ -309,5 +309,8 @@ limitations under the License.
|
||||
|
||||
</div> <!-- outerContainer -->
|
||||
<div id="printContainer"></div>
|
||||
<!--#if !(FIREFOX || MOZCENTRAL)-->
|
||||
<!--#include viewer-snippet-mozPrintCallback-polyfill.html-->
|
||||
<!--#endif--->
|
||||
</body>
|
||||
</html>
|
||||
|
@ -56,6 +56,11 @@ PDFJS.imageResourcesPath = './images/';
|
||||
var mozL10n = document.mozL10n || document.webL10n;
|
||||
|
||||
//#include ui_utils.js
|
||||
|
||||
//#if !(FIREFOX || MOZCENTRAL || B2G)
|
||||
//#include mozPrintCallback_polyfill.js
|
||||
//#endif
|
||||
|
||||
//#if GENERIC || CHROME
|
||||
//#include download_manager.js
|
||||
//#endif
|
||||
|
Loading…
Reference in New Issue
Block a user