Merge pull request #9577 from Snuffleupagus/pagesize-info-fixes
[api-minor] Fix various issues related to pageSize, and display the size for the active page in the document properties dialog
This commit is contained in:
commit
0d391daccc
@ -90,12 +90,12 @@ document_properties_producer=PDF Producer:
|
|||||||
document_properties_version=PDF Version:
|
document_properties_version=PDF Version:
|
||||||
document_properties_page_count=Page Count:
|
document_properties_page_count=Page Count:
|
||||||
document_properties_page_size=Page Size:
|
document_properties_page_size=Page Size:
|
||||||
# LOCALIZATION NOTE (document_properties_page_size_in): "{{width_in}}" and "{{height_in}}"
|
# LOCALIZATION NOTE (document_properties_page_size_in_2): "{{width}}" and "{{height}}"
|
||||||
# will be replaced by the size of the first page of the PDF file in inches.
|
# will be replaced by the size of the (current) page, in inches.
|
||||||
document_properties_page_size_in={{width_in}}in × {{height_in}}in
|
document_properties_page_size_in_2={{width}} × {{height}} in
|
||||||
# LOCALIZATION NOTE (document_properties_page_size_mm): "{{width_mm}}" and "{{height_mm}}"
|
# LOCALIZATION NOTE (document_properties_page_size_mm_2): "{{width}}" and "{{height}}"
|
||||||
# will be replaced by the size of the first page of the PDF file in millimeters.
|
# will be replaced by the size of the (current) page, in millimeters.
|
||||||
document_properties_page_size_mm={{width_mm}}mm × {{height_mm}}mm
|
document_properties_page_size_mm_2={{width}} × {{height}} mm
|
||||||
document_properties_close=Close
|
document_properties_close=Close
|
||||||
|
|
||||||
print_progress_message=Preparing document for printing…
|
print_progress_message=Preparing document for printing…
|
||||||
|
@ -89,6 +89,13 @@ document_properties_creator=Skapare:
|
|||||||
document_properties_producer=PDF-producent:
|
document_properties_producer=PDF-producent:
|
||||||
document_properties_version=PDF-version:
|
document_properties_version=PDF-version:
|
||||||
document_properties_page_count=Sidantal:
|
document_properties_page_count=Sidantal:
|
||||||
|
document_properties_page_size=Sidstorlek:
|
||||||
|
# LOCALIZATION NOTE (document_properties_page_size_in_2): "{{width}}" and "{{height}}"
|
||||||
|
# will be replaced by the size of the (current) page, in inches.
|
||||||
|
document_properties_page_size_in_2={{width}} × {{height}} tum
|
||||||
|
# LOCALIZATION NOTE (document_properties_page_size_mm_2): "{{width}}" and "{{height}}"
|
||||||
|
# will be replaced by the size of the (current) page, in millimeters.
|
||||||
|
document_properties_page_size_mm_2={{width}} × {{height}} mm
|
||||||
document_properties_close=Stäng
|
document_properties_close=Stäng
|
||||||
|
|
||||||
print_progress_message=Förbereder sidor för utskrift…
|
print_progress_message=Förbereder sidor för utskrift…
|
||||||
|
@ -692,23 +692,6 @@ var PDFDocumentProxy = (function PDFDocumentProxyClosure() {
|
|||||||
getMetadata: function PDFDocumentProxy_getMetadata() {
|
getMetadata: function PDFDocumentProxy_getMetadata() {
|
||||||
return this.transport.getMetadata();
|
return this.transport.getMetadata();
|
||||||
},
|
},
|
||||||
/**
|
|
||||||
* @param {number} pageNumber The page number to get the page size from.
|
|
||||||
* The first page is 1, which is also the default page used.
|
|
||||||
* @return {Promise} A promise that is resolved with an dict containing the
|
|
||||||
* width and height in inches.
|
|
||||||
*/
|
|
||||||
getPageSizeInches(pageNumber) {
|
|
||||||
pageNumber = pageNumber || 1;
|
|
||||||
return this.getPage(pageNumber).then((page) => {
|
|
||||||
const [x1, y1, x2, y2] = page.view;
|
|
||||||
// convert values from user units to inches
|
|
||||||
return {
|
|
||||||
width: (x2 - x1) / 72 * page.userUnit,
|
|
||||||
height: (y2 - y1) / 72 * page.userUnit,
|
|
||||||
};
|
|
||||||
});
|
|
||||||
},
|
|
||||||
/**
|
/**
|
||||||
* @return {Promise} A promise that is resolved with a TypedArray that has
|
* @return {Promise} A promise that is resolved with a TypedArray that has
|
||||||
* the raw data from the PDF.
|
* the raw data from the PDF.
|
||||||
@ -890,6 +873,20 @@ var PDFPageProxy = (function PDFPageProxyClosure() {
|
|||||||
get view() {
|
get view() {
|
||||||
return this.pageInfo.view;
|
return this.pageInfo.view;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The size of the current page, converted from PDF units to inches.
|
||||||
|
* @return {Object} An Object containing the properties: {number} `width`
|
||||||
|
* and {number} `height`, given in inches.
|
||||||
|
*/
|
||||||
|
get pageSizeInches() {
|
||||||
|
const [x1, y1, x2, y2] = this.view, userUnit = this.userUnit;
|
||||||
|
return {
|
||||||
|
width: (x2 - x1) / 72 * userUnit,
|
||||||
|
height: (y2 - y1) / 72 * userUnit,
|
||||||
|
};
|
||||||
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param {number} scale The desired scale of the viewport.
|
* @param {number} scale The desired scale of the viewport.
|
||||||
* @param {number} rotate Degrees to rotate the viewport. If omitted this
|
* @param {number} rotate Degrees to rotate the viewport. If omitted this
|
||||||
|
@ -964,6 +964,14 @@ describe('api', function() {
|
|||||||
it('gets view', function () {
|
it('gets view', function () {
|
||||||
expect(page.view).toEqual([0, 0, 595.28, 841.89]);
|
expect(page.view).toEqual([0, 0, 595.28, 841.89]);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('gets page size (in inches)', function() {
|
||||||
|
const { width, height, } = page.pageSizeInches;
|
||||||
|
|
||||||
|
expect(+width.toPrecision(3)).toEqual(8.27);
|
||||||
|
expect(+height.toPrecision(4)).toEqual(11.69);
|
||||||
|
});
|
||||||
|
|
||||||
it('gets viewport', function () {
|
it('gets viewport', function () {
|
||||||
var viewport = page.getViewport(1.5, 90);
|
var viewport = page.getViewport(1.5, 90);
|
||||||
expect(viewport.viewBox).toEqual(page.view);
|
expect(viewport.viewBox).toEqual(page.view);
|
||||||
|
@ -429,7 +429,7 @@ let PDFViewerApplication = {
|
|||||||
|
|
||||||
this.pdfDocumentProperties =
|
this.pdfDocumentProperties =
|
||||||
new PDFDocumentProperties(appConfig.documentProperties,
|
new PDFDocumentProperties(appConfig.documentProperties,
|
||||||
this.overlayManager, this.l10n);
|
this.overlayManager, eventBus, this.l10n);
|
||||||
|
|
||||||
this.pdfCursorTools = new PDFCursorTools({
|
this.pdfCursorTools = new PDFCursorTools({
|
||||||
container,
|
container,
|
||||||
|
@ -30,10 +30,11 @@ class PDFDocumentProperties {
|
|||||||
/**
|
/**
|
||||||
* @param {PDFDocumentPropertiesOptions} options
|
* @param {PDFDocumentPropertiesOptions} options
|
||||||
* @param {OverlayManager} overlayManager - Manager for the viewer overlays.
|
* @param {OverlayManager} overlayManager - Manager for the viewer overlays.
|
||||||
|
* @param {EventBus} eventBus - The application event bus.
|
||||||
* @param {IL10n} l10n - Localization service.
|
* @param {IL10n} l10n - Localization service.
|
||||||
*/
|
*/
|
||||||
constructor({ overlayName, fields, container, closeButton, },
|
constructor({ overlayName, fields, container, closeButton, },
|
||||||
overlayManager, l10n = NullL10n) {
|
overlayManager, eventBus, l10n = NullL10n) {
|
||||||
this.overlayName = overlayName;
|
this.overlayName = overlayName;
|
||||||
this.fields = fields;
|
this.fields = fields;
|
||||||
this.container = container;
|
this.container = container;
|
||||||
@ -47,6 +48,12 @@ class PDFDocumentProperties {
|
|||||||
}
|
}
|
||||||
this.overlayManager.register(this.overlayName, this.container,
|
this.overlayManager.register(this.overlayName, this.container,
|
||||||
this.close.bind(this));
|
this.close.bind(this));
|
||||||
|
|
||||||
|
if (eventBus) {
|
||||||
|
eventBus.on('pagechanging', (evt) => {
|
||||||
|
this._currentPageNumber = evt.pageNumber;
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -64,12 +71,16 @@ class PDFDocumentProperties {
|
|||||||
|
|
||||||
Promise.all([this.overlayManager.open(this.overlayName),
|
Promise.all([this.overlayManager.open(this.overlayName),
|
||||||
this._dataAvailableCapability.promise]).then(() => {
|
this._dataAvailableCapability.promise]).then(() => {
|
||||||
|
const currentPageNumber = this._currentPageNumber;
|
||||||
|
|
||||||
// If the document properties were previously fetched (for this PDF file),
|
// If the document properties were previously fetched (for this PDF file),
|
||||||
// just update the dialog immediately to avoid redundant lookups.
|
// just update the dialog immediately to avoid redundant lookups.
|
||||||
if (this.fieldData) {
|
if (this.fieldData &&
|
||||||
|
currentPageNumber === this.fieldData['_currentPageNumber']) {
|
||||||
this._updateUI();
|
this._updateUI();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get the document properties.
|
// Get the document properties.
|
||||||
this.pdfDocument.getMetadata().then(
|
this.pdfDocument.getMetadata().then(
|
||||||
({ info, metadata, contentDispositionFilename, }) => {
|
({ info, metadata, contentDispositionFilename, }) => {
|
||||||
@ -80,13 +91,12 @@ class PDFDocumentProperties {
|
|||||||
this._parseFileSize(this.maybeFileSize),
|
this._parseFileSize(this.maybeFileSize),
|
||||||
this._parseDate(info.CreationDate),
|
this._parseDate(info.CreationDate),
|
||||||
this._parseDate(info.ModDate),
|
this._parseDate(info.ModDate),
|
||||||
this.pdfDocument.getPageSizeInches().then((pageSizeInches) => {
|
this.pdfDocument.getPage(currentPageNumber).then((pdfPage) => {
|
||||||
return this._parsePageSize(pageSizeInches);
|
return this._parsePageSize(pdfPage.pageSizeInches);
|
||||||
}),
|
}),
|
||||||
|
|
||||||
]);
|
]);
|
||||||
}).then(([info, metadata, fileName, fileSize,
|
}).then(([info, metadata, fileName, fileSize, creationDate, modDate,
|
||||||
creationDate, modDate, pageSize]) => {
|
pageSizes]) => {
|
||||||
freezeFieldData({
|
freezeFieldData({
|
||||||
'fileName': fileName,
|
'fileName': fileName,
|
||||||
'fileSize': fileSize,
|
'fileSize': fileSize,
|
||||||
@ -100,8 +110,9 @@ class PDFDocumentProperties {
|
|||||||
'producer': info.Producer,
|
'producer': info.Producer,
|
||||||
'version': info.PDFFormatVersion,
|
'version': info.PDFFormatVersion,
|
||||||
'pageCount': this.pdfDocument.numPages,
|
'pageCount': this.pdfDocument.numPages,
|
||||||
'pageSizeInch': pageSize.inch,
|
'pageSizeInch': pageSizes.inch,
|
||||||
'pageSizeMM': pageSize.mm,
|
'pageSizeMM': pageSizes.mm,
|
||||||
|
'_currentPageNumber': currentPageNumber,
|
||||||
});
|
});
|
||||||
this._updateUI();
|
this._updateUI();
|
||||||
|
|
||||||
@ -109,8 +120,12 @@ class PDFDocumentProperties {
|
|||||||
// `this.setFileSize` wasn't called) or may be incorrectly set.
|
// `this.setFileSize` wasn't called) or may be incorrectly set.
|
||||||
return this.pdfDocument.getDownloadInfo();
|
return this.pdfDocument.getDownloadInfo();
|
||||||
}).then(({ length, }) => {
|
}).then(({ length, }) => {
|
||||||
|
this.maybeFileSize = length;
|
||||||
return this._parseFileSize(length);
|
return this._parseFileSize(length);
|
||||||
}).then((fileSize) => {
|
}).then((fileSize) => {
|
||||||
|
if (fileSize === this.fieldData['fileSize']) {
|
||||||
|
return; // The fileSize has already been correctly set.
|
||||||
|
}
|
||||||
let data = cloneObj(this.fieldData);
|
let data = cloneObj(this.fieldData);
|
||||||
data['fileSize'] = fileSize;
|
data['fileSize'] = fileSize;
|
||||||
|
|
||||||
@ -158,7 +173,7 @@ class PDFDocumentProperties {
|
|||||||
* @param {number} fileSize - The file size of the PDF document.
|
* @param {number} fileSize - The file size of the PDF document.
|
||||||
*/
|
*/
|
||||||
setFileSize(fileSize) {
|
setFileSize(fileSize) {
|
||||||
if (typeof fileSize === 'number' && fileSize > 0) {
|
if (Number.isInteger(fileSize) && fileSize > 0) {
|
||||||
this.maybeFileSize = fileSize;
|
this.maybeFileSize = fileSize;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -173,6 +188,7 @@ class PDFDocumentProperties {
|
|||||||
this.maybeFileSize = 0;
|
this.maybeFileSize = 0;
|
||||||
delete this.fieldData;
|
delete this.fieldData;
|
||||||
this._dataAvailableCapability = createPromiseCapability();
|
this._dataAvailableCapability = createPromiseCapability();
|
||||||
|
this._currentPageNumber = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -224,25 +240,25 @@ class PDFDocumentProperties {
|
|||||||
*/
|
*/
|
||||||
_parsePageSize(pageSizeInches) {
|
_parsePageSize(pageSizeInches) {
|
||||||
if (!pageSizeInches) {
|
if (!pageSizeInches) {
|
||||||
return Promise.resolve([undefined, undefined]);
|
return Promise.resolve({ inch: undefined, mm: undefined, });
|
||||||
}
|
}
|
||||||
const sizes_two_units = {
|
const { width, height, } = pageSizeInches;
|
||||||
'width_in': Math.round(pageSizeInches.width * 100) / 100,
|
|
||||||
'height_in': Math.round(pageSizeInches.height * 100) / 100,
|
|
||||||
// 1in = 25.4mm; no need to round to 2 decimals for mm
|
|
||||||
'width_mm': Math.round(pageSizeInches.width * 25.4 * 10) / 10,
|
|
||||||
'height_mm': Math.round(pageSizeInches.height * 25.4 * 10) / 10,
|
|
||||||
};
|
|
||||||
return Promise.all([
|
return Promise.all([
|
||||||
this.l10n.get('document_properties_page_size_in',
|
this.l10n.get('document_properties_page_size_in_2', {
|
||||||
sizes_two_units, '{{width_in}} in × {{height_in}} in'),
|
width: (Math.round(width * 100) / 100).toLocaleString(),
|
||||||
this.l10n.get('document_properties_page_size_mm',
|
height: (Math.round(height * 100) / 100).toLocaleString(),
|
||||||
sizes_two_units, '{{width_mm}} mm × {{height_mm}} mm'),
|
}, '{{width}} × {{height}} in'),
|
||||||
]).then(([parsedPageSizeInches, parsedPageSizeMM]) => {
|
// 1in = 25.4mm; no need to round to 2 decimals for millimeters.
|
||||||
return Promise.resolve({
|
this.l10n.get('document_properties_page_size_mm_2', {
|
||||||
inch: parsedPageSizeInches,
|
width: (Math.round(width * 25.4 * 10) / 10).toLocaleString(),
|
||||||
mm: parsedPageSizeMM,
|
height: (Math.round(height * 25.4 * 10) / 10).toLocaleString(),
|
||||||
});
|
}, '{{width}} × {{height}} mm'),
|
||||||
|
]).then((sizes) => {
|
||||||
|
return {
|
||||||
|
inch: sizes[0],
|
||||||
|
mm: sizes[1],
|
||||||
|
};
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user