From 4ed3290cde6178ba4dbebeb085a86a2e83fffd44 Mon Sep 17 00:00:00 2001 From: Nikischin Date: Sun, 2 Jun 2024 13:16:39 +0200 Subject: [PATCH 1/2] Possible fix for dpi (untested) --- packages/layout/src/page/getSize.js | 15 --------------- packages/layout/src/steps/resolveStyles.js | 2 +- packages/stylesheet/src/transform/units.js | 2 +- 3 files changed, 2 insertions(+), 17 deletions(-) diff --git a/packages/layout/src/page/getSize.js b/packages/layout/src/page/getSize.js index 76ee76aa6..6db1191a5 100644 --- a/packages/layout/src/page/getSize.js +++ b/packages/layout/src/page/getSize.js @@ -70,18 +70,6 @@ const toSizeObject = (v) => ({ width: v[0], height: v[1] }); */ const flipSizeObject = (v) => ({ width: v.height, height: v.width }); -/** - * Adjust page size to passed DPI - * - * @param {{ width: number, height: number }} v size object - * @param {number} dpi DPI - * @returns {{ width: number, height: number }} adjusted size object - */ -const adjustDpi = (v, dpi) => ({ - width: v.width ? v.width * dpi : v.width, - height: v.height ? v.height * dpi : v.height, -}); - /** * Returns size object from a given string * @@ -108,7 +96,6 @@ const getNumberSize = (n) => toSizeObject([n]); */ const getSize = (page) => { const value = page.props?.size || 'A4'; - const dpi = parseFloat(page.props?.dpi || 72); const type = typeof value; @@ -127,8 +114,6 @@ const getSize = (page) => { size = value; } - size = adjustDpi(size, dpi / 72); - return isLandscape(page) ? flipSizeObject(size) : size; }; diff --git a/packages/layout/src/steps/resolveStyles.js b/packages/layout/src/steps/resolveStyles.js index 1c24b3c8d..b94637432 100644 --- a/packages/layout/src/steps/resolveStyles.js +++ b/packages/layout/src/steps/resolveStyles.js @@ -56,7 +56,7 @@ const resolveNodeStyles = (container) => (node) => { * @returns {Object} document page with resolved styles */ export const resolvePageStyles = (page) => { - const dpi = page.props?.dpi || 72; + const dpi = 72; // Removed: page.props?.dpi || 72; const width = page.box?.width || page.style.width; const height = page.box?.height || page.style.height; const orientation = page.props?.orientation || 'portrait'; diff --git a/packages/stylesheet/src/transform/units.js b/packages/stylesheet/src/transform/units.js index c4f18fe96..01ec54b2e 100644 --- a/packages/stylesheet/src/transform/units.js +++ b/packages/stylesheet/src/transform/units.js @@ -22,7 +22,7 @@ const parseValue = (value) => { const transformUnit = (container, value) => { const scalar = parseValue(value); - const dpi = container.dpi || 72; + const dpi = 72; // Removed: container.dpi || 72 const mmFactor = (1 / 25.4) * dpi; const cmFactor = (1 / 2.54) * dpi; From f5b8ecab944359678885c58889945cb35e749f27 Mon Sep 17 00:00:00 2001 From: Nikischin Date: Sun, 2 Jun 2024 14:34:45 +0200 Subject: [PATCH 2/2] Allow to pass pixel sizes --- .changeset/pretty-jars-begin.md | 9 +++++++++ packages/layout/src/page/getSize.js | 16 ++++++++++++++++ 2 files changed, 25 insertions(+) create mode 100644 .changeset/pretty-jars-begin.md diff --git a/.changeset/pretty-jars-begin.md b/.changeset/pretty-jars-begin.md new file mode 100644 index 000000000..aa5edf5c6 --- /dev/null +++ b/.changeset/pretty-jars-begin.md @@ -0,0 +1,9 @@ +--- +'@react-pdf/layout': minor +'@react-pdf/pdfkit': minor +'@react-pdf/render': minor +'@react-pdf/stylesheet': minor +'@react-pdf/types': minor +--- + +fix: fix dpi \ No newline at end of file diff --git a/packages/layout/src/page/getSize.js b/packages/layout/src/page/getSize.js index 6db1191a5..4fe676a2d 100644 --- a/packages/layout/src/page/getSize.js +++ b/packages/layout/src/page/getSize.js @@ -70,6 +70,18 @@ const toSizeObject = (v) => ({ width: v[0], height: v[1] }); */ const flipSizeObject = (v) => ({ width: v.height, height: v.width }); +/** + * Adjust page size to passed DPI + * + * @param {{ width: number, height: number }} v size object + * @param {number} dpi DPI + * @returns {{ width: number, height: number }} adjusted size object + */ +const adjustDpi = (v, dpi) => ({ + width: v.width ? v.width * (72 / dpi) : v.width, + height: v.height ? v.height * (72 / dpi) : v.height, +}); + /** * Returns size object from a given string * @@ -96,6 +108,7 @@ const getNumberSize = (n) => toSizeObject([n]); */ const getSize = (page) => { const value = page.props?.size || 'A4'; + const dpi = parseFloat(page.props?.dpi || 72); const type = typeof value; @@ -108,10 +121,13 @@ const getSize = (page) => { size = getStringSize(value); } else if (Array.isArray(value)) { size = toSizeObject(value); + size = adjustDpi(size, dpi); } else if (type === 'number') { size = getNumberSize(value); + size = adjustDpi(size, dpi); } else { size = value; + size = adjustDpi(size, dpi); } return isLandscape(page) ? flipSizeObject(size) : size;