html2canvas-pro 2.0.3 → 2.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/README.md +8 -6
- package/dist/html2canvas-pro.esm.js +6754 -6599
- package/dist/html2canvas-pro.esm.js.map +1 -1
- package/dist/html2canvas-pro.js +6753 -6599
- package/dist/html2canvas-pro.js.map +1 -1
- package/dist/html2canvas-pro.min.js +5 -5
- package/dist/lib/config.js +3 -4
- package/dist/lib/core/bitwise.js +0 -1
- package/dist/lib/core/cache-storage.js +34 -48
- package/dist/lib/core/context.js +0 -1
- package/dist/lib/core/debugger.js +0 -1
- package/dist/lib/core/features.js +0 -1
- package/dist/lib/core/logger.js +0 -1
- package/dist/lib/core/origin-checker.js +0 -1
- package/dist/lib/core/performance-monitor.js +1 -24
- package/dist/lib/core/render-element.js +210 -0
- package/dist/lib/core/util.js +0 -1
- package/dist/lib/core/validator.js +0 -1
- package/dist/lib/css/index.js +150 -89
- package/dist/lib/css/layout/bounds.js +0 -1
- package/dist/lib/css/layout/text.js +4 -1
- package/dist/lib/css/{ITypeDescriptor.js → property-descriptor.js} +0 -1
- package/dist/lib/css/property-descriptors/background-clip.js +0 -1
- package/dist/lib/css/property-descriptors/background-color.js +0 -1
- package/dist/lib/css/property-descriptors/background-image.js +0 -1
- package/dist/lib/css/property-descriptors/background-origin.js +0 -1
- package/dist/lib/css/property-descriptors/background-position.js +0 -1
- package/dist/lib/css/property-descriptors/background-repeat.js +0 -1
- package/dist/lib/css/property-descriptors/background-size.js +0 -1
- package/dist/lib/css/property-descriptors/border-color.js +0 -1
- package/dist/lib/css/property-descriptors/border-radius.js +0 -1
- package/dist/lib/css/property-descriptors/border-style.js +0 -1
- package/dist/lib/css/property-descriptors/border-width.js +0 -1
- package/dist/lib/css/property-descriptors/box-shadow.js +0 -1
- package/dist/lib/css/property-descriptors/clip-path.js +0 -1
- package/dist/lib/css/property-descriptors/color.js +0 -1
- package/dist/lib/css/property-descriptors/content.js +0 -1
- package/dist/lib/css/property-descriptors/counter-increment.js +0 -1
- package/dist/lib/css/property-descriptors/counter-reset.js +0 -1
- package/dist/lib/css/property-descriptors/direction.js +0 -1
- package/dist/lib/css/property-descriptors/display.js +0 -1
- package/dist/lib/css/property-descriptors/duration.js +0 -1
- package/dist/lib/css/property-descriptors/float.js +0 -1
- package/dist/lib/css/property-descriptors/font-family.js +0 -1
- package/dist/lib/css/property-descriptors/font-size.js +0 -1
- package/dist/lib/css/property-descriptors/font-style.js +0 -1
- package/dist/lib/css/property-descriptors/font-variant.js +0 -1
- package/dist/lib/css/property-descriptors/font-weight.js +0 -1
- package/dist/lib/css/property-descriptors/image-rendering.js +0 -1
- package/dist/lib/css/property-descriptors/letter-spacing.js +0 -1
- package/dist/lib/css/property-descriptors/line-break.js +0 -1
- package/dist/lib/css/property-descriptors/line-height.js +0 -1
- package/dist/lib/css/property-descriptors/list-style-image.js +0 -1
- package/dist/lib/css/property-descriptors/list-style-position.js +0 -1
- package/dist/lib/css/property-descriptors/list-style-type.js +0 -1
- package/dist/lib/css/property-descriptors/margin.js +0 -1
- package/dist/lib/css/property-descriptors/mix-blend-mode.js +31 -0
- package/dist/lib/css/property-descriptors/object-fit.js +0 -1
- package/dist/lib/css/property-descriptors/opacity.js +0 -1
- package/dist/lib/css/property-descriptors/overflow-wrap.js +0 -1
- package/dist/lib/css/property-descriptors/overflow.js +0 -1
- package/dist/lib/css/property-descriptors/padding.js +0 -1
- package/dist/lib/css/property-descriptors/paint-order.js +0 -1
- package/dist/lib/css/property-descriptors/position.js +0 -1
- package/dist/lib/css/property-descriptors/quotes.js +0 -1
- package/dist/lib/css/property-descriptors/rotate.js +0 -1
- package/dist/lib/css/property-descriptors/text-align.js +0 -1
- package/dist/lib/css/property-descriptors/text-decoration-color.js +0 -1
- package/dist/lib/css/property-descriptors/text-decoration-line.js +0 -1
- package/dist/lib/css/property-descriptors/text-decoration-style.js +0 -1
- package/dist/lib/css/property-descriptors/text-decoration-thickness.js +0 -1
- package/dist/lib/css/property-descriptors/text-overflow.js +0 -1
- package/dist/lib/css/property-descriptors/text-shadow.js +0 -1
- package/dist/lib/css/property-descriptors/text-transform.js +0 -1
- package/dist/lib/css/property-descriptors/text-underline-offset.js +0 -1
- package/dist/lib/css/property-descriptors/transform-origin.js +0 -1
- package/dist/lib/css/property-descriptors/transform.js +0 -1
- package/dist/lib/css/property-descriptors/visibility.js +0 -1
- package/dist/lib/css/property-descriptors/webkit-line-clamp.js +0 -1
- package/dist/lib/css/property-descriptors/webkit-text-stroke-color.js +0 -1
- package/dist/lib/css/property-descriptors/webkit-text-stroke-width.js +0 -1
- package/dist/lib/css/property-descriptors/word-break.js +0 -1
- package/dist/lib/css/property-descriptors/writing-mode.js +28 -0
- package/dist/lib/css/property-descriptors/z-index.js +0 -1
- package/dist/lib/css/syntax/parser.js +0 -1
- package/dist/lib/css/syntax/tokenizer.js +14 -1
- package/dist/lib/css/{IPropertyDescriptor.js → type-descriptor.js} +0 -1
- package/dist/lib/css/types/angle.js +0 -1
- package/dist/lib/css/types/color-math.js +0 -1
- package/dist/lib/css/types/color-spaces/a98.js +0 -1
- package/dist/lib/css/types/color-spaces/p3.js +0 -1
- package/dist/lib/css/types/color-spaces/pro-photo.js +0 -1
- package/dist/lib/css/types/color-spaces/rec2020.js +0 -1
- package/dist/lib/css/types/color-spaces/srgb.js +0 -1
- package/dist/lib/css/types/color-utilities.js +0 -1
- package/dist/lib/css/types/color.js +0 -1
- package/dist/lib/css/types/functions/-prefix-linear-gradient.js +0 -1
- package/dist/lib/css/types/functions/-prefix-radial-gradient.js +0 -1
- package/dist/lib/css/types/functions/-webkit-gradient.js +0 -1
- package/dist/lib/css/types/functions/counter.js +0 -1
- package/dist/lib/css/types/functions/gradient.js +0 -1
- package/dist/lib/css/types/functions/linear-gradient.js +0 -1
- package/dist/lib/css/types/functions/radial-gradient.js +0 -1
- package/dist/lib/css/types/image.js +0 -1
- package/dist/lib/css/types/index.js +0 -1
- package/dist/lib/css/types/length-percentage.js +0 -1
- package/dist/lib/css/types/length.js +0 -1
- package/dist/lib/css/types/time.js +0 -1
- package/dist/lib/dom/document-cloner.js +27 -22
- package/dist/lib/dom/dom-normalizer.js +0 -1
- package/dist/lib/dom/element-container.js +7 -6
- package/dist/lib/dom/elements/li-element-container.js +0 -1
- package/dist/lib/dom/elements/ol-element-container.js +0 -1
- package/dist/lib/dom/elements/select-element-container.js +0 -1
- package/dist/lib/dom/elements/textarea-element-container.js +0 -1
- package/dist/lib/dom/node-parser.js +37 -53
- package/dist/lib/dom/node-type-guards.js +62 -25
- package/dist/lib/dom/replaced-elements/canvas-element-container.js +0 -1
- package/dist/lib/dom/replaced-elements/iframe-element-container.js +0 -1
- package/dist/lib/dom/replaced-elements/image-element-container.js +0 -1
- package/dist/lib/dom/replaced-elements/index.js +0 -1
- package/dist/lib/dom/replaced-elements/input-element-container.js +0 -1
- package/dist/lib/dom/replaced-elements/pseudo-elements.js +0 -1
- package/dist/lib/dom/replaced-elements/svg-element-container.js +0 -1
- package/dist/lib/dom/text-container.js +5 -1
- package/dist/lib/index.js +32 -210
- package/dist/lib/invariant.js +0 -1
- package/dist/lib/options.js +2 -0
- package/dist/lib/render/background.js +0 -1
- package/dist/lib/render/bezier-curve.js +0 -1
- package/dist/lib/render/border.js +0 -1
- package/dist/lib/render/bound-curves.js +0 -1
- package/dist/lib/render/box-sizing.js +0 -1
- package/dist/lib/render/canvas/background-renderer.js +2 -24
- package/dist/lib/render/canvas/border-renderer.js +0 -1
- package/dist/lib/render/canvas/canvas-path.js +25 -0
- package/dist/lib/render/canvas/canvas-renderer.js +25 -98
- package/dist/lib/render/canvas/effects-renderer.js +3 -1
- package/dist/lib/render/canvas/foreignobject-renderer.js +8 -16
- package/dist/lib/render/canvas/text-renderer.js +92 -121
- package/dist/lib/render/effects.js +11 -2
- package/dist/lib/render/font-metrics.js +0 -1
- package/dist/lib/render/object-fit.js +87 -0
- package/dist/lib/render/path.js +0 -1
- package/dist/lib/render/renderer-interface.js +0 -1
- package/dist/lib/render/stacking-context.js +16 -8
- package/dist/lib/render/vector.js +0 -1
- package/dist/types/core/cache-storage.d.ts +5 -6
- package/dist/types/core/performance-monitor.d.ts +0 -11
- package/dist/types/core/render-element.d.ts +3 -0
- package/dist/types/css/index.d.ts +5 -0
- package/dist/types/css/property-descriptors/background-clip.d.ts +1 -1
- package/dist/types/css/property-descriptors/background-color.d.ts +1 -1
- package/dist/types/css/property-descriptors/background-image.d.ts +1 -1
- package/dist/types/css/property-descriptors/background-origin.d.ts +1 -1
- package/dist/types/css/property-descriptors/background-position.d.ts +1 -1
- package/dist/types/css/property-descriptors/background-repeat.d.ts +1 -1
- package/dist/types/css/property-descriptors/background-size.d.ts +1 -1
- package/dist/types/css/property-descriptors/border-color.d.ts +1 -1
- package/dist/types/css/property-descriptors/border-radius.d.ts +1 -1
- package/dist/types/css/property-descriptors/border-style.d.ts +1 -1
- package/dist/types/css/property-descriptors/border-width.d.ts +1 -1
- package/dist/types/css/property-descriptors/box-shadow.d.ts +1 -1
- package/dist/types/css/property-descriptors/clip-path.d.ts +1 -1
- package/dist/types/css/property-descriptors/color.d.ts +1 -1
- package/dist/types/css/property-descriptors/content.d.ts +1 -1
- package/dist/types/css/property-descriptors/counter-increment.d.ts +1 -1
- package/dist/types/css/property-descriptors/counter-reset.d.ts +1 -1
- package/dist/types/css/property-descriptors/direction.d.ts +1 -1
- package/dist/types/css/property-descriptors/display.d.ts +1 -1
- package/dist/types/css/property-descriptors/duration.d.ts +1 -1
- package/dist/types/css/property-descriptors/float.d.ts +1 -1
- package/dist/types/css/property-descriptors/font-family.d.ts +1 -1
- package/dist/types/css/property-descriptors/font-size.d.ts +1 -1
- package/dist/types/css/property-descriptors/font-style.d.ts +1 -1
- package/dist/types/css/property-descriptors/font-variant.d.ts +1 -1
- package/dist/types/css/property-descriptors/font-weight.d.ts +1 -1
- package/dist/types/css/property-descriptors/image-rendering.d.ts +1 -1
- package/dist/types/css/property-descriptors/letter-spacing.d.ts +1 -1
- package/dist/types/css/property-descriptors/line-break.d.ts +1 -1
- package/dist/types/css/property-descriptors/line-height.d.ts +1 -1
- package/dist/types/css/property-descriptors/list-style-image.d.ts +1 -1
- package/dist/types/css/property-descriptors/list-style-position.d.ts +1 -1
- package/dist/types/css/property-descriptors/list-style-type.d.ts +1 -1
- package/dist/types/css/property-descriptors/margin.d.ts +1 -1
- package/dist/types/css/property-descriptors/mix-blend-mode.d.ts +21 -0
- package/dist/types/css/property-descriptors/object-fit.d.ts +1 -1
- package/dist/types/css/property-descriptors/opacity.d.ts +1 -1
- package/dist/types/css/property-descriptors/overflow-wrap.d.ts +1 -1
- package/dist/types/css/property-descriptors/overflow.d.ts +1 -1
- package/dist/types/css/property-descriptors/padding.d.ts +1 -1
- package/dist/types/css/property-descriptors/paint-order.d.ts +1 -1
- package/dist/types/css/property-descriptors/position.d.ts +1 -1
- package/dist/types/css/property-descriptors/quotes.d.ts +1 -1
- package/dist/types/css/property-descriptors/rotate.d.ts +1 -1
- package/dist/types/css/property-descriptors/text-align.d.ts +1 -1
- package/dist/types/css/property-descriptors/text-decoration-color.d.ts +1 -1
- package/dist/types/css/property-descriptors/text-decoration-line.d.ts +1 -1
- package/dist/types/css/property-descriptors/text-decoration-style.d.ts +1 -1
- package/dist/types/css/property-descriptors/text-decoration-thickness.d.ts +1 -1
- package/dist/types/css/property-descriptors/text-overflow.d.ts +1 -1
- package/dist/types/css/property-descriptors/text-shadow.d.ts +1 -1
- package/dist/types/css/property-descriptors/text-transform.d.ts +1 -1
- package/dist/types/css/property-descriptors/text-underline-offset.d.ts +1 -1
- package/dist/types/css/property-descriptors/transform-origin.d.ts +1 -1
- package/dist/types/css/property-descriptors/transform.d.ts +1 -1
- package/dist/types/css/property-descriptors/visibility.d.ts +1 -1
- package/dist/types/css/property-descriptors/webkit-line-clamp.d.ts +1 -1
- package/dist/types/css/property-descriptors/webkit-text-stroke-color.d.ts +1 -1
- package/dist/types/css/property-descriptors/webkit-text-stroke-width.d.ts +1 -1
- package/dist/types/css/property-descriptors/word-break.d.ts +1 -1
- package/dist/types/css/property-descriptors/writing-mode.d.ts +11 -0
- package/dist/types/css/property-descriptors/z-index.d.ts +1 -1
- package/dist/types/css/syntax/tokenizer.d.ts +5 -0
- package/dist/types/css/types/angle.d.ts +1 -1
- package/dist/types/css/types/color.d.ts +1 -1
- package/dist/types/css/types/image.d.ts +1 -1
- package/dist/types/css/types/time.d.ts +1 -1
- package/dist/types/dom/element-container.d.ts +4 -11
- package/dist/types/dom/node-parser.d.ts +2 -15
- package/dist/types/dom/node-type-guards.d.ts +21 -22
- package/dist/types/index.d.ts +28 -48
- package/dist/types/options.d.ts +51 -0
- package/dist/types/render/canvas/background-renderer.d.ts +0 -6
- package/dist/types/render/canvas/canvas-path.d.ts +3 -0
- package/dist/types/render/canvas/canvas-renderer.d.ts +4 -2
- package/dist/types/render/canvas/foreignobject-renderer.d.ts +2 -3
- package/dist/types/render/canvas/text-renderer.d.ts +8 -1
- package/dist/types/render/effects.d.ts +9 -1
- package/dist/types/render/object-fit.d.ts +18 -0
- package/package.json +43 -35
- package/src/__tests__/index.ts +99 -0
- package/src/config.ts +107 -0
- package/src/core/__mocks__/cache-storage.ts +1 -0
- package/src/core/__mocks__/context.ts +19 -0
- package/{dist/lib/core/__mocks__/features.js → src/core/__mocks__/features.ts} +1 -5
- package/src/core/__mocks__/logger.ts +17 -0
- package/{dist/lib/core/__tests__/cache-storage.test.js → src/core/__tests__/cache-storage.test.ts} +95 -48
- package/{dist/lib/core/__tests__/cache-storage.js → src/core/__tests__/cache-storage.ts} +117 -64
- package/{dist/lib/core/__tests__/logger.js → src/core/__tests__/logger.ts} +10 -8
- package/{dist/lib/core/__tests__/validator.js → src/core/__tests__/validator.ts} +161 -98
- package/src/core/bitwise.ts +1 -0
- package/src/core/cache-storage.ts +315 -0
- package/src/core/context.ts +31 -0
- package/src/core/debugger.ts +32 -0
- package/src/core/features.ts +222 -0
- package/src/core/logger.ts +64 -0
- package/src/core/origin-checker.ts +57 -0
- package/src/core/performance-monitor.ts +241 -0
- package/src/core/render-element.ts +272 -0
- package/src/core/util.ts +1 -0
- package/src/core/validator.ts +593 -0
- package/src/css/index.ts +427 -0
- package/src/css/layout/__mocks__/bounds.ts +6 -0
- package/src/css/layout/bounds.ts +79 -0
- package/src/css/layout/text.ts +161 -0
- package/src/css/property-descriptor.ts +49 -0
- package/src/css/property-descriptors/__tests__/background-tests.ts +65 -0
- package/src/css/property-descriptors/__tests__/clip-path.test.ts +280 -0
- package/src/css/property-descriptors/__tests__/font-family.ts +25 -0
- package/src/css/property-descriptors/__tests__/image-rendering-integration.test.ts +153 -0
- package/{dist/lib/css/property-descriptors/__tests__/image-rendering-performance.test.js → src/css/property-descriptors/__tests__/image-rendering-performance.test.ts} +74 -66
- package/src/css/property-descriptors/__tests__/image-rendering.test.ts +72 -0
- package/src/css/property-descriptors/__tests__/paint-order.ts +87 -0
- package/src/css/property-descriptors/__tests__/text-shadow.ts +94 -0
- package/src/css/property-descriptors/__tests__/transform-tests.ts +18 -0
- package/src/css/property-descriptors/background-clip.ts +30 -0
- package/src/css/property-descriptors/background-color.ts +9 -0
- package/src/css/property-descriptors/background-image.ts +27 -0
- package/src/css/property-descriptors/background-origin.ts +31 -0
- package/src/css/property-descriptors/background-position.ts +38 -0
- package/src/css/property-descriptors/background-repeat.ts +44 -0
- package/src/css/property-descriptors/background-size.ts +27 -0
- package/src/css/property-descriptors/border-color.ts +13 -0
- package/src/css/property-descriptors/border-radius.ts +19 -0
- package/src/css/property-descriptors/border-style.ts +34 -0
- package/src/css/property-descriptors/border-width.ts +20 -0
- package/src/css/property-descriptors/box-shadow.ts +60 -0
- package/src/css/property-descriptors/clip-path.ts +271 -0
- package/src/css/property-descriptors/color.ts +9 -0
- package/src/css/property-descriptors/content.ts +26 -0
- package/src/css/property-descriptors/counter-increment.ts +43 -0
- package/src/css/property-descriptors/counter-reset.ts +36 -0
- package/src/css/property-descriptors/direction.ts +23 -0
- package/src/css/property-descriptors/display.ts +117 -0
- package/src/css/property-descriptors/duration.ts +14 -0
- package/src/css/property-descriptors/float.ts +29 -0
- package/src/css/property-descriptors/font-family.ts +38 -0
- package/src/css/property-descriptors/font-size.ts +9 -0
- package/src/css/property-descriptors/font-style.ts +25 -0
- package/src/css/property-descriptors/font-variant.ts +12 -0
- package/src/css/property-descriptors/font-weight.ts +26 -0
- package/src/css/property-descriptors/image-rendering.ts +33 -0
- package/src/css/property-descriptors/letter-spacing.ts +25 -0
- package/src/css/property-descriptors/line-break.ts +22 -0
- package/src/css/property-descriptors/line-height.ts +22 -0
- package/src/css/property-descriptors/list-style-image.ts +19 -0
- package/src/css/property-descriptors/list-style-position.ts +22 -0
- package/src/css/property-descriptors/list-style-type.ts +179 -0
- package/src/css/property-descriptors/margin.ts +13 -0
- package/src/css/property-descriptors/mix-blend-mode.ts +35 -0
- package/src/css/property-descriptors/object-fit.ts +39 -0
- package/src/css/property-descriptors/opacity.ts +15 -0
- package/src/css/property-descriptors/overflow-wrap.ts +22 -0
- package/src/css/property-descriptors/overflow.ts +34 -0
- package/src/css/property-descriptors/padding.ts +14 -0
- package/src/css/property-descriptors/paint-order.ts +42 -0
- package/src/css/property-descriptors/position.ts +30 -0
- package/src/css/property-descriptors/quotes.ts +57 -0
- package/src/css/property-descriptors/rotate.ts +34 -0
- package/src/css/property-descriptors/text-align.ts +26 -0
- package/src/css/property-descriptors/text-decoration-color.ts +9 -0
- package/src/css/property-descriptors/text-decoration-line.ts +38 -0
- package/src/css/property-descriptors/text-decoration-style.ts +32 -0
- package/src/css/property-descriptors/text-decoration-thickness.ts +30 -0
- package/src/css/property-descriptors/text-overflow.ts +23 -0
- package/src/css/property-descriptors/text-shadow.ts +52 -0
- package/src/css/property-descriptors/text-transform.ts +27 -0
- package/src/css/property-descriptors/text-underline-offset.ts +27 -0
- package/src/css/property-descriptors/transform-origin.ts +29 -0
- package/src/css/property-descriptors/transform.ts +74 -0
- package/src/css/property-descriptors/visibility.ts +25 -0
- package/src/css/property-descriptors/webkit-line-clamp.ts +30 -0
- package/src/css/property-descriptors/webkit-text-stroke-color.ts +8 -0
- package/src/css/property-descriptors/webkit-text-stroke-width.ts +15 -0
- package/src/css/property-descriptors/word-break.ts +25 -0
- package/src/css/property-descriptors/writing-mode.ts +37 -0
- package/src/css/property-descriptors/z-index.ts +27 -0
- package/src/css/syntax/__tests__/tokernizer-tests.ts +29 -0
- package/src/css/syntax/parser.ts +188 -0
- package/src/css/syntax/tokenizer.ts +822 -0
- package/src/css/type-descriptor.ts +7 -0
- package/src/css/types/__tests__/color-tests.ts +147 -0
- package/src/css/types/__tests__/image-tests.ts +239 -0
- package/src/css/types/angle.ts +86 -0
- package/src/css/types/color-math.ts +22 -0
- package/src/css/types/color-spaces/a98.ts +86 -0
- package/src/css/types/color-spaces/p3.ts +92 -0
- package/src/css/types/color-spaces/pro-photo.ts +87 -0
- package/src/css/types/color-spaces/rec2020.ts +90 -0
- package/src/css/types/color-spaces/srgb.ts +87 -0
- package/src/css/types/color-utilities.ts +452 -0
- package/src/css/types/color.ts +485 -0
- package/src/css/types/functions/-prefix-linear-gradient.ts +35 -0
- package/src/css/types/functions/-prefix-radial-gradient.ts +106 -0
- package/src/css/types/functions/-webkit-gradient.ts +69 -0
- package/src/css/types/functions/__tests__/radial-gradient.ts +69 -0
- package/src/css/types/functions/counter.ts +511 -0
- package/src/css/types/functions/gradient.ts +206 -0
- package/src/css/types/functions/linear-gradient.ts +28 -0
- package/src/css/types/functions/radial-gradient.ts +101 -0
- package/src/css/types/image.ts +120 -0
- package/src/css/types/index.ts +1 -0
- package/src/css/types/length-percentage.ts +137 -0
- package/src/css/types/length.ts +7 -0
- package/src/css/types/time.ts +20 -0
- package/src/dom/__mocks__/document-cloner.ts +22 -0
- package/{dist/lib/dom/__tests__/dom-normalizer.test.js → src/dom/__tests__/dom-normalizer.test.ts} +64 -44
- package/src/dom/__tests__/element-container.test.ts +129 -0
- package/src/dom/document-cloner.ts +929 -0
- package/src/dom/dom-normalizer.ts +133 -0
- package/src/dom/element-container.ts +75 -0
- package/src/dom/elements/li-element-container.ts +10 -0
- package/src/dom/elements/ol-element-container.ts +12 -0
- package/src/dom/elements/select-element-container.ts +10 -0
- package/src/dom/elements/textarea-element-container.ts +9 -0
- package/src/dom/node-parser.ts +177 -0
- package/src/dom/node-type-guards.ts +70 -0
- package/src/dom/replaced-elements/canvas-element-container.ts +15 -0
- package/src/dom/replaced-elements/iframe-element-container.ts +55 -0
- package/src/dom/replaced-elements/image-element-container.ts +16 -0
- package/src/dom/replaced-elements/index.ts +5 -0
- package/src/dom/replaced-elements/input-element-container.ts +105 -0
- package/src/dom/replaced-elements/pseudo-elements.ts +0 -0
- package/src/dom/replaced-elements/svg-element-container.ts +23 -0
- package/src/dom/text-container.ts +42 -0
- package/src/global.d.ts +19 -0
- package/src/index.ts +82 -0
- package/src/invariant.ts +5 -0
- package/src/options.ts +55 -0
- package/src/render/__tests__/object-fit.test.ts +85 -0
- package/src/render/background.ts +298 -0
- package/src/render/bezier-curve.ts +47 -0
- package/src/render/border.ts +165 -0
- package/src/render/bound-curves.ts +388 -0
- package/src/render/box-sizing.ts +31 -0
- package/{dist/lib/render/canvas/__tests__/background-renderer.test.js → src/render/canvas/__tests__/background-renderer.test.ts} +32 -25
- package/src/render/canvas/__tests__/border-renderer.test.ts +24 -0
- package/src/render/canvas/__tests__/effects-renderer.test.ts +32 -0
- package/src/render/canvas/__tests__/text-renderer.test.ts +471 -0
- package/src/render/canvas/background-renderer.ts +271 -0
- package/src/render/canvas/border-renderer.ts +224 -0
- package/src/render/canvas/canvas-path.ts +31 -0
- package/src/render/canvas/canvas-renderer.ts +641 -0
- package/src/render/canvas/effects-renderer.ts +130 -0
- package/src/render/canvas/foreignobject-renderer.ts +53 -0
- package/src/render/canvas/text-renderer.ts +700 -0
- package/src/render/effects.ts +75 -0
- package/src/render/font-metrics.ts +72 -0
- package/src/render/object-fit.ts +100 -0
- package/src/render/path.ts +37 -0
- package/src/render/renderer-interface.ts +28 -0
- package/src/render/stacking-context.ts +386 -0
- package/src/render/vector.ts +19 -0
- package/demo/image-smoothing-demo.html +0 -256
- package/demo/refactoring-test.html +0 -602
- package/dist/lib/__tests__/index.js +0 -85
- package/dist/lib/__tests__/index.js.map +0 -1
- package/dist/lib/config.js.map +0 -1
- package/dist/lib/core/__mocks__/cache-storage.js +0 -7
- package/dist/lib/core/__mocks__/cache-storage.js.map +0 -1
- package/dist/lib/core/__mocks__/context.js +0 -19
- package/dist/lib/core/__mocks__/context.js.map +0 -1
- package/dist/lib/core/__mocks__/features.js.map +0 -1
- package/dist/lib/core/__mocks__/logger.js +0 -16
- package/dist/lib/core/__mocks__/logger.js.map +0 -1
- package/dist/lib/core/__tests__/cache-storage.js.map +0 -1
- package/dist/lib/core/__tests__/cache-storage.test.js.map +0 -1
- package/dist/lib/core/__tests__/logger.js.map +0 -1
- package/dist/lib/core/__tests__/validator.js.map +0 -1
- package/dist/lib/core/bitwise.js.map +0 -1
- package/dist/lib/core/cache-storage.js.map +0 -1
- package/dist/lib/core/context.js.map +0 -1
- package/dist/lib/core/debugger.js.map +0 -1
- package/dist/lib/core/features.js.map +0 -1
- package/dist/lib/core/logger.js.map +0 -1
- package/dist/lib/core/origin-checker.js.map +0 -1
- package/dist/lib/core/performance-monitor.js.map +0 -1
- package/dist/lib/core/util.js.map +0 -1
- package/dist/lib/core/validator.js.map +0 -1
- package/dist/lib/css/IPropertyDescriptor.js.map +0 -1
- package/dist/lib/css/ITypeDescriptor.js.map +0 -1
- package/dist/lib/css/index.js.map +0 -1
- package/dist/lib/css/layout/__mocks__/bounds.js +0 -9
- package/dist/lib/css/layout/__mocks__/bounds.js.map +0 -1
- package/dist/lib/css/layout/bounds.js.map +0 -1
- package/dist/lib/css/layout/text.js.map +0 -1
- package/dist/lib/css/property-descriptors/__tests__/background-tests.js +0 -49
- package/dist/lib/css/property-descriptors/__tests__/background-tests.js.map +0 -1
- package/dist/lib/css/property-descriptors/__tests__/clip-path.test.js +0 -273
- package/dist/lib/css/property-descriptors/__tests__/clip-path.test.js.map +0 -1
- package/dist/lib/css/property-descriptors/__tests__/font-family.js +0 -19
- package/dist/lib/css/property-descriptors/__tests__/font-family.js.map +0 -1
- package/dist/lib/css/property-descriptors/__tests__/image-rendering-integration.test.js +0 -143
- package/dist/lib/css/property-descriptors/__tests__/image-rendering-integration.test.js.map +0 -1
- package/dist/lib/css/property-descriptors/__tests__/image-rendering-performance.test.js.map +0 -1
- package/dist/lib/css/property-descriptors/__tests__/image-rendering.test.js +0 -61
- package/dist/lib/css/property-descriptors/__tests__/image-rendering.test.js.map +0 -1
- package/dist/lib/css/property-descriptors/__tests__/paint-order.js +0 -66
- package/dist/lib/css/property-descriptors/__tests__/paint-order.js.map +0 -1
- package/dist/lib/css/property-descriptors/__tests__/text-shadow.js +0 -82
- package/dist/lib/css/property-descriptors/__tests__/text-shadow.js.map +0 -1
- package/dist/lib/css/property-descriptors/__tests__/transform-tests.js +0 -14
- package/dist/lib/css/property-descriptors/__tests__/transform-tests.js.map +0 -1
- package/dist/lib/css/property-descriptors/background-clip.js.map +0 -1
- package/dist/lib/css/property-descriptors/background-color.js.map +0 -1
- package/dist/lib/css/property-descriptors/background-image.js.map +0 -1
- package/dist/lib/css/property-descriptors/background-origin.js.map +0 -1
- package/dist/lib/css/property-descriptors/background-position.js.map +0 -1
- package/dist/lib/css/property-descriptors/background-repeat.js.map +0 -1
- package/dist/lib/css/property-descriptors/background-size.js.map +0 -1
- package/dist/lib/css/property-descriptors/border-color.js.map +0 -1
- package/dist/lib/css/property-descriptors/border-radius.js.map +0 -1
- package/dist/lib/css/property-descriptors/border-style.js.map +0 -1
- package/dist/lib/css/property-descriptors/border-width.js.map +0 -1
- package/dist/lib/css/property-descriptors/box-shadow.js.map +0 -1
- package/dist/lib/css/property-descriptors/clip-path.js.map +0 -1
- package/dist/lib/css/property-descriptors/color.js.map +0 -1
- package/dist/lib/css/property-descriptors/content.js.map +0 -1
- package/dist/lib/css/property-descriptors/counter-increment.js.map +0 -1
- package/dist/lib/css/property-descriptors/counter-reset.js.map +0 -1
- package/dist/lib/css/property-descriptors/direction.js.map +0 -1
- package/dist/lib/css/property-descriptors/display.js.map +0 -1
- package/dist/lib/css/property-descriptors/duration.js.map +0 -1
- package/dist/lib/css/property-descriptors/float.js.map +0 -1
- package/dist/lib/css/property-descriptors/font-family.js.map +0 -1
- package/dist/lib/css/property-descriptors/font-size.js.map +0 -1
- package/dist/lib/css/property-descriptors/font-style.js.map +0 -1
- package/dist/lib/css/property-descriptors/font-variant.js.map +0 -1
- package/dist/lib/css/property-descriptors/font-weight.js.map +0 -1
- package/dist/lib/css/property-descriptors/image-rendering.js.map +0 -1
- package/dist/lib/css/property-descriptors/letter-spacing.js.map +0 -1
- package/dist/lib/css/property-descriptors/line-break.js.map +0 -1
- package/dist/lib/css/property-descriptors/line-height.js.map +0 -1
- package/dist/lib/css/property-descriptors/list-style-image.js.map +0 -1
- package/dist/lib/css/property-descriptors/list-style-position.js.map +0 -1
- package/dist/lib/css/property-descriptors/list-style-type.js.map +0 -1
- package/dist/lib/css/property-descriptors/margin.js.map +0 -1
- package/dist/lib/css/property-descriptors/object-fit.js.map +0 -1
- package/dist/lib/css/property-descriptors/opacity.js.map +0 -1
- package/dist/lib/css/property-descriptors/overflow-wrap.js.map +0 -1
- package/dist/lib/css/property-descriptors/overflow.js.map +0 -1
- package/dist/lib/css/property-descriptors/padding.js.map +0 -1
- package/dist/lib/css/property-descriptors/paint-order.js.map +0 -1
- package/dist/lib/css/property-descriptors/position.js.map +0 -1
- package/dist/lib/css/property-descriptors/quotes.js.map +0 -1
- package/dist/lib/css/property-descriptors/rotate.js.map +0 -1
- package/dist/lib/css/property-descriptors/text-align.js.map +0 -1
- package/dist/lib/css/property-descriptors/text-decoration-color.js.map +0 -1
- package/dist/lib/css/property-descriptors/text-decoration-line.js.map +0 -1
- package/dist/lib/css/property-descriptors/text-decoration-style.js.map +0 -1
- package/dist/lib/css/property-descriptors/text-decoration-thickness.js.map +0 -1
- package/dist/lib/css/property-descriptors/text-overflow.js.map +0 -1
- package/dist/lib/css/property-descriptors/text-shadow.js.map +0 -1
- package/dist/lib/css/property-descriptors/text-transform.js.map +0 -1
- package/dist/lib/css/property-descriptors/text-underline-offset.js.map +0 -1
- package/dist/lib/css/property-descriptors/transform-origin.js.map +0 -1
- package/dist/lib/css/property-descriptors/transform.js.map +0 -1
- package/dist/lib/css/property-descriptors/visibility.js.map +0 -1
- package/dist/lib/css/property-descriptors/webkit-line-clamp.js.map +0 -1
- package/dist/lib/css/property-descriptors/webkit-text-stroke-color.js.map +0 -1
- package/dist/lib/css/property-descriptors/webkit-text-stroke-width.js.map +0 -1
- package/dist/lib/css/property-descriptors/word-break.js.map +0 -1
- package/dist/lib/css/property-descriptors/z-index.js.map +0 -1
- package/dist/lib/css/syntax/__tests__/tokernizer-tests.js +0 -26
- package/dist/lib/css/syntax/__tests__/tokernizer-tests.js.map +0 -1
- package/dist/lib/css/syntax/parser.js.map +0 -1
- package/dist/lib/css/syntax/tokenizer.js.map +0 -1
- package/dist/lib/css/types/__tests__/color-tests.js +0 -111
- package/dist/lib/css/types/__tests__/color-tests.js.map +0 -1
- package/dist/lib/css/types/__tests__/image-tests.js +0 -215
- package/dist/lib/css/types/__tests__/image-tests.js.map +0 -1
- package/dist/lib/css/types/angle.js.map +0 -1
- package/dist/lib/css/types/color-math.js.map +0 -1
- package/dist/lib/css/types/color-spaces/a98.js.map +0 -1
- package/dist/lib/css/types/color-spaces/p3.js.map +0 -1
- package/dist/lib/css/types/color-spaces/pro-photo.js.map +0 -1
- package/dist/lib/css/types/color-spaces/rec2020.js.map +0 -1
- package/dist/lib/css/types/color-spaces/srgb.js.map +0 -1
- package/dist/lib/css/types/color-utilities.js.map +0 -1
- package/dist/lib/css/types/color.js.map +0 -1
- package/dist/lib/css/types/functions/-prefix-linear-gradient.js.map +0 -1
- package/dist/lib/css/types/functions/-prefix-radial-gradient.js.map +0 -1
- package/dist/lib/css/types/functions/-webkit-gradient.js.map +0 -1
- package/dist/lib/css/types/functions/__tests__/radial-gradient.js +0 -63
- package/dist/lib/css/types/functions/__tests__/radial-gradient.js.map +0 -1
- package/dist/lib/css/types/functions/counter.js.map +0 -1
- package/dist/lib/css/types/functions/gradient.js.map +0 -1
- package/dist/lib/css/types/functions/linear-gradient.js.map +0 -1
- package/dist/lib/css/types/functions/radial-gradient.js.map +0 -1
- package/dist/lib/css/types/image.js.map +0 -1
- package/dist/lib/css/types/index.js.map +0 -1
- package/dist/lib/css/types/length-percentage.js.map +0 -1
- package/dist/lib/css/types/length.js.map +0 -1
- package/dist/lib/css/types/time.js.map +0 -1
- package/dist/lib/dom/__mocks__/document-cloner.js +0 -23
- package/dist/lib/dom/__mocks__/document-cloner.js.map +0 -1
- package/dist/lib/dom/__tests__/dom-normalizer.test.js.map +0 -1
- package/dist/lib/dom/__tests__/element-container.test.js +0 -109
- package/dist/lib/dom/__tests__/element-container.test.js.map +0 -1
- package/dist/lib/dom/document-cloner.js.map +0 -1
- package/dist/lib/dom/dom-normalizer.js.map +0 -1
- package/dist/lib/dom/element-container.js.map +0 -1
- package/dist/lib/dom/elements/li-element-container.js.map +0 -1
- package/dist/lib/dom/elements/ol-element-container.js.map +0 -1
- package/dist/lib/dom/elements/select-element-container.js.map +0 -1
- package/dist/lib/dom/elements/textarea-element-container.js.map +0 -1
- package/dist/lib/dom/node-parser.js.map +0 -1
- package/dist/lib/dom/node-type-guards.js.map +0 -1
- package/dist/lib/dom/replaced-elements/canvas-element-container.js.map +0 -1
- package/dist/lib/dom/replaced-elements/iframe-element-container.js.map +0 -1
- package/dist/lib/dom/replaced-elements/image-element-container.js.map +0 -1
- package/dist/lib/dom/replaced-elements/index.js.map +0 -1
- package/dist/lib/dom/replaced-elements/input-element-container.js.map +0 -1
- package/dist/lib/dom/replaced-elements/pseudo-elements.js.map +0 -1
- package/dist/lib/dom/replaced-elements/svg-element-container.js.map +0 -1
- package/dist/lib/dom/text-container.js.map +0 -1
- package/dist/lib/index.js.map +0 -1
- package/dist/lib/invariant.js.map +0 -1
- package/dist/lib/render/background.js.map +0 -1
- package/dist/lib/render/bezier-curve.js.map +0 -1
- package/dist/lib/render/border.js.map +0 -1
- package/dist/lib/render/bound-curves.js.map +0 -1
- package/dist/lib/render/box-sizing.js.map +0 -1
- package/dist/lib/render/canvas/__tests__/background-renderer.test.js.map +0 -1
- package/dist/lib/render/canvas/__tests__/border-renderer.test.js +0 -23
- package/dist/lib/render/canvas/__tests__/border-renderer.test.js.map +0 -1
- package/dist/lib/render/canvas/__tests__/effects-renderer.test.js +0 -30
- package/dist/lib/render/canvas/__tests__/effects-renderer.test.js.map +0 -1
- package/dist/lib/render/canvas/__tests__/text-renderer.test.js +0 -310
- package/dist/lib/render/canvas/__tests__/text-renderer.test.js.map +0 -1
- package/dist/lib/render/canvas/background-renderer.js.map +0 -1
- package/dist/lib/render/canvas/border-renderer.js.map +0 -1
- package/dist/lib/render/canvas/canvas-renderer.js.map +0 -1
- package/dist/lib/render/canvas/effects-renderer.js.map +0 -1
- package/dist/lib/render/canvas/foreignobject-renderer.js.map +0 -1
- package/dist/lib/render/canvas/text-renderer.js.map +0 -1
- package/dist/lib/render/effects.js.map +0 -1
- package/dist/lib/render/font-metrics.js.map +0 -1
- package/dist/lib/render/path.js.map +0 -1
- package/dist/lib/render/renderer-interface.js.map +0 -1
- package/dist/lib/render/renderer.js +0 -11
- package/dist/lib/render/renderer.js.map +0 -1
- package/dist/lib/render/stacking-context.js.map +0 -1
- package/dist/lib/render/vector.js.map +0 -1
- package/dist/types/__tests__/index.d.ts +0 -1
- package/dist/types/core/__mocks__/cache-storage.d.ts +0 -2
- package/dist/types/core/__mocks__/context.d.ts +0 -9
- package/dist/types/core/__mocks__/features.d.ts +0 -8
- package/dist/types/core/__mocks__/logger.d.ts +0 -9
- package/dist/types/core/__tests__/cache-storage.d.ts +0 -1
- package/dist/types/core/__tests__/cache-storage.test.d.ts +0 -1
- package/dist/types/core/__tests__/logger.d.ts +0 -1
- package/dist/types/core/__tests__/validator.d.ts +0 -1
- package/dist/types/css/layout/__mocks__/bounds.d.ts +0 -2
- package/dist/types/css/property-descriptors/__tests__/background-tests.d.ts +0 -1
- package/dist/types/css/property-descriptors/__tests__/clip-path.test.d.ts +0 -1
- package/dist/types/css/property-descriptors/__tests__/font-family.d.ts +0 -1
- package/dist/types/css/property-descriptors/__tests__/image-rendering-integration.test.d.ts +0 -1
- package/dist/types/css/property-descriptors/__tests__/image-rendering-performance.test.d.ts +0 -1
- package/dist/types/css/property-descriptors/__tests__/image-rendering.test.d.ts +0 -1
- package/dist/types/css/property-descriptors/__tests__/paint-order.d.ts +0 -1
- package/dist/types/css/property-descriptors/__tests__/text-shadow.d.ts +0 -1
- package/dist/types/css/property-descriptors/__tests__/transform-tests.d.ts +0 -1
- package/dist/types/css/syntax/__tests__/tokernizer-tests.d.ts +0 -1
- package/dist/types/css/types/__tests__/color-tests.d.ts +0 -1
- package/dist/types/css/types/__tests__/image-tests.d.ts +0 -1
- package/dist/types/css/types/functions/__tests__/radial-gradient.d.ts +0 -1
- package/dist/types/dom/__mocks__/document-cloner.d.ts +0 -6
- package/dist/types/dom/__tests__/dom-normalizer.test.d.ts +0 -1
- package/dist/types/dom/__tests__/element-container.test.d.ts +0 -1
- package/dist/types/render/canvas/__tests__/background-renderer.test.d.ts +0 -1
- package/dist/types/render/canvas/__tests__/border-renderer.test.d.ts +0 -1
- package/dist/types/render/canvas/__tests__/effects-renderer.test.d.ts +0 -1
- package/dist/types/render/canvas/__tests__/text-renderer.test.d.ts +0 -1
- package/dist/types/render/renderer.d.ts +0 -7
- package/eslint.config.js +0 -35
- package/jest.config.cjs +0 -5
- package/karma.conf.cjs +0 -300
- /package/dist/types/css/{IPropertyDescriptor.d.ts → property-descriptor.d.ts} +0 -0
- /package/dist/types/css/{ITypeDescriptor.d.ts → type-descriptor.d.ts} +0 -0
|
@@ -16,8 +16,8 @@ const background_1 = require("../background");
|
|
|
16
16
|
const gradient_1 = require("../../css/types/functions/gradient");
|
|
17
17
|
const length_percentage_1 = require("../../css/types/length-percentage");
|
|
18
18
|
const color_utilities_1 = require("../../css/types/color-utilities");
|
|
19
|
-
const bezier_curve_1 = require("../bezier-curve");
|
|
20
19
|
const image_rendering_1 = require("../../css/property-descriptors/image-rendering");
|
|
20
|
+
const canvas_path_1 = require("./canvas-path");
|
|
21
21
|
/**
|
|
22
22
|
* Background Renderer
|
|
23
23
|
*
|
|
@@ -194,29 +194,7 @@ class BackgroundRenderer {
|
|
|
194
194
|
* @param paths - Array of path points
|
|
195
195
|
*/
|
|
196
196
|
path(paths) {
|
|
197
|
-
this.ctx
|
|
198
|
-
this.formatPath(paths);
|
|
199
|
-
this.ctx.closePath();
|
|
200
|
-
}
|
|
201
|
-
/**
|
|
202
|
-
* Format path points into canvas path
|
|
203
|
-
*
|
|
204
|
-
* @param paths - Array of path points
|
|
205
|
-
*/
|
|
206
|
-
formatPath(paths) {
|
|
207
|
-
paths.forEach((point, index) => {
|
|
208
|
-
const start = (0, bezier_curve_1.isBezierCurve)(point) ? point.start : point;
|
|
209
|
-
if (index === 0) {
|
|
210
|
-
this.ctx.moveTo(start.x, start.y);
|
|
211
|
-
}
|
|
212
|
-
else {
|
|
213
|
-
this.ctx.lineTo(start.x, start.y);
|
|
214
|
-
}
|
|
215
|
-
if ((0, bezier_curve_1.isBezierCurve)(point)) {
|
|
216
|
-
this.ctx.bezierCurveTo(point.startControl.x, point.startControl.y, point.endControl.x, point.endControl.y, point.end.x, point.end.y);
|
|
217
|
-
}
|
|
218
|
-
});
|
|
197
|
+
(0, canvas_path_1.createCanvasPath)(this.ctx, paths);
|
|
219
198
|
}
|
|
220
199
|
}
|
|
221
200
|
exports.BackgroundRenderer = BackgroundRenderer;
|
|
222
|
-
//# sourceMappingURL=background-renderer.js.map
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createCanvasPath = exports.formatCanvasPath = void 0;
|
|
4
|
+
const bezier_curve_1 = require("../bezier-curve");
|
|
5
|
+
const formatCanvasPath = (ctx, paths) => {
|
|
6
|
+
paths.forEach((point, index) => {
|
|
7
|
+
const start = (0, bezier_curve_1.isBezierCurve)(point) ? point.start : point;
|
|
8
|
+
if (index === 0) {
|
|
9
|
+
ctx.moveTo(start.x, start.y);
|
|
10
|
+
}
|
|
11
|
+
else {
|
|
12
|
+
ctx.lineTo(start.x, start.y);
|
|
13
|
+
}
|
|
14
|
+
if ((0, bezier_curve_1.isBezierCurve)(point)) {
|
|
15
|
+
ctx.bezierCurveTo(point.startControl.x, point.startControl.y, point.endControl.x, point.endControl.y, point.end.x, point.end.y);
|
|
16
|
+
}
|
|
17
|
+
});
|
|
18
|
+
};
|
|
19
|
+
exports.formatCanvasPath = formatCanvasPath;
|
|
20
|
+
const createCanvasPath = (ctx, paths) => {
|
|
21
|
+
ctx.beginPath();
|
|
22
|
+
(0, exports.formatCanvasPath)(ctx, paths);
|
|
23
|
+
ctx.closePath();
|
|
24
|
+
};
|
|
25
|
+
exports.createCanvasPath = createCanvasPath;
|
|
@@ -5,7 +5,6 @@ const stacking_context_1 = require("../stacking-context");
|
|
|
5
5
|
const color_utilities_1 = require("../../css/types/color-utilities");
|
|
6
6
|
const path_1 = require("../path");
|
|
7
7
|
const bound_curves_1 = require("../bound-curves");
|
|
8
|
-
const bezier_curve_1 = require("../bezier-curve");
|
|
9
8
|
const vector_1 = require("../vector");
|
|
10
9
|
const background_1 = require("../background");
|
|
11
10
|
const text_1 = require("../../css/layout/text");
|
|
@@ -23,15 +22,17 @@ const input_element_container_1 = require("../../dom/replaced-elements/input-ele
|
|
|
23
22
|
const textarea_element_container_1 = require("../../dom/elements/textarea-element-container");
|
|
24
23
|
const select_element_container_1 = require("../../dom/elements/select-element-container");
|
|
25
24
|
const iframe_element_container_1 = require("../../dom/replaced-elements/iframe-element-container");
|
|
26
|
-
const renderer_1 = require("../renderer");
|
|
27
25
|
const background_renderer_1 = require("./background-renderer");
|
|
28
26
|
const border_renderer_1 = require("./border-renderer");
|
|
29
27
|
const effects_renderer_1 = require("./effects-renderer");
|
|
30
28
|
const text_renderer_1 = require("./text-renderer");
|
|
29
|
+
const canvas_path_1 = require("./canvas-path");
|
|
30
|
+
const object_fit_1 = require("../object-fit");
|
|
31
31
|
const MASK_OFFSET = 10000;
|
|
32
|
-
class CanvasRenderer
|
|
32
|
+
class CanvasRenderer {
|
|
33
33
|
constructor(context, options) {
|
|
34
|
-
|
|
34
|
+
this.context = context;
|
|
35
|
+
this.options = options;
|
|
35
36
|
this.canvas = options.canvas ? options.canvas : document.createElement('canvas');
|
|
36
37
|
this.ctx = this.canvas.getContext('2d');
|
|
37
38
|
if (!options.canvas) {
|
|
@@ -81,7 +82,7 @@ class CanvasRenderer extends renderer_1.Renderer {
|
|
|
81
82
|
}
|
|
82
83
|
}
|
|
83
84
|
async renderNode(paint) {
|
|
84
|
-
if (
|
|
85
|
+
if (paint.container.debugRender) {
|
|
85
86
|
debugger;
|
|
86
87
|
}
|
|
87
88
|
if (paint.container.styles.isVisible()) {
|
|
@@ -103,80 +104,7 @@ class CanvasRenderer extends renderer_1.Renderer {
|
|
|
103
104
|
this.path(path);
|
|
104
105
|
this.ctx.save();
|
|
105
106
|
this.ctx.clip();
|
|
106
|
-
|
|
107
|
-
const { objectFit } = container.styles;
|
|
108
|
-
const boxRatio = dw / dh;
|
|
109
|
-
const imgRatio = sw / sh;
|
|
110
|
-
if (objectFit === 2 /* OBJECT_FIT.CONTAIN */) {
|
|
111
|
-
if (imgRatio > boxRatio) {
|
|
112
|
-
dh = dw / imgRatio;
|
|
113
|
-
dy += (box.height - dh) / 2;
|
|
114
|
-
}
|
|
115
|
-
else {
|
|
116
|
-
dw = dh * imgRatio;
|
|
117
|
-
dx += (box.width - dw) / 2;
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
else if (objectFit === 4 /* OBJECT_FIT.COVER */) {
|
|
121
|
-
if (imgRatio > boxRatio) {
|
|
122
|
-
sw = sh * boxRatio;
|
|
123
|
-
sx += (intrinsicWidth - sw) / 2;
|
|
124
|
-
}
|
|
125
|
-
else {
|
|
126
|
-
sh = sw / boxRatio;
|
|
127
|
-
sy += (intrinsicHeight - sh) / 2;
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
else if (objectFit === 8 /* OBJECT_FIT.NONE */) {
|
|
131
|
-
if (sw > dw) {
|
|
132
|
-
sx += (sw - dw) / 2;
|
|
133
|
-
sw = dw;
|
|
134
|
-
}
|
|
135
|
-
else {
|
|
136
|
-
dx += (dw - sw) / 2;
|
|
137
|
-
dw = sw;
|
|
138
|
-
}
|
|
139
|
-
if (sh > dh) {
|
|
140
|
-
sy += (sh - dh) / 2;
|
|
141
|
-
sh = dh;
|
|
142
|
-
}
|
|
143
|
-
else {
|
|
144
|
-
dy += (dh - sh) / 2;
|
|
145
|
-
dh = sh;
|
|
146
|
-
}
|
|
147
|
-
}
|
|
148
|
-
else if (objectFit === 16 /* OBJECT_FIT.SCALE_DOWN */) {
|
|
149
|
-
const containW = imgRatio > boxRatio ? dw : dh * imgRatio;
|
|
150
|
-
const noneW = sw > dw ? sw : dw;
|
|
151
|
-
if (containW < noneW) {
|
|
152
|
-
if (imgRatio > boxRatio) {
|
|
153
|
-
dh = dw / imgRatio;
|
|
154
|
-
dy += (box.height - dh) / 2;
|
|
155
|
-
}
|
|
156
|
-
else {
|
|
157
|
-
dw = dh * imgRatio;
|
|
158
|
-
dx += (box.width - dw) / 2;
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
else {
|
|
162
|
-
if (sw > dw) {
|
|
163
|
-
sx += (sw - dw) / 2;
|
|
164
|
-
sw = dw;
|
|
165
|
-
}
|
|
166
|
-
else {
|
|
167
|
-
dx += (dw - sw) / 2;
|
|
168
|
-
dw = sw;
|
|
169
|
-
}
|
|
170
|
-
if (sh > dh) {
|
|
171
|
-
sy += (sh - dh) / 2;
|
|
172
|
-
sh = dh;
|
|
173
|
-
}
|
|
174
|
-
else {
|
|
175
|
-
dy += (dh - sh) / 2;
|
|
176
|
-
dh = sh;
|
|
177
|
-
}
|
|
178
|
-
}
|
|
179
|
-
}
|
|
107
|
+
const { sx, sy, sw, sh, dx, dy, dw, dh } = (0, object_fit_1.calculateObjectFitRendering)(intrinsicWidth, intrinsicHeight, box, container.styles.objectFit);
|
|
180
108
|
this.ctx.drawImage(image, sx, sy, sw, sh, dx, dy, dw, dh);
|
|
181
109
|
this.ctx.restore();
|
|
182
110
|
}
|
|
@@ -309,7 +237,7 @@ class CanvasRenderer extends renderer_1.Renderer {
|
|
|
309
237
|
new vector_1.Vector(bounds.left, bounds.top + bounds.height)
|
|
310
238
|
]);
|
|
311
239
|
this.ctx.clip();
|
|
312
|
-
this.textRenderer.renderTextWithLetterSpacing(new text_1.TextBounds(container.value, textBounds), styles.letterSpacing, baseline);
|
|
240
|
+
this.textRenderer.renderTextWithLetterSpacing(new text_1.TextBounds(container.value, textBounds), styles.letterSpacing, baseline, styles.writingMode);
|
|
313
241
|
this.ctx.restore();
|
|
314
242
|
this.ctx.textBaseline = 'alphabetic';
|
|
315
243
|
this.ctx.textAlign = 'left';
|
|
@@ -336,24 +264,29 @@ class CanvasRenderer extends renderer_1.Renderer {
|
|
|
336
264
|
this.ctx.textBaseline = 'middle';
|
|
337
265
|
this.ctx.textAlign = 'right';
|
|
338
266
|
const bounds = new bounds_1.Bounds(container.bounds.left, container.bounds.top + (0, length_percentage_1.getAbsoluteValue)(container.styles.paddingTop, container.bounds.width), container.bounds.width, (0, line_height_1.computeLineHeight)(styles.lineHeight, styles.fontSize.number) / 2 + 1);
|
|
339
|
-
this.textRenderer.renderTextWithLetterSpacing(new text_1.TextBounds(paint.listValue, bounds), styles.letterSpacing, (0, line_height_1.computeLineHeight)(styles.lineHeight, styles.fontSize.number) / 2 + 2);
|
|
267
|
+
this.textRenderer.renderTextWithLetterSpacing(new text_1.TextBounds(paint.listValue, bounds), styles.letterSpacing, (0, line_height_1.computeLineHeight)(styles.lineHeight, styles.fontSize.number) / 2 + 2, styles.writingMode);
|
|
340
268
|
this.ctx.textBaseline = 'bottom';
|
|
341
269
|
this.ctx.textAlign = 'left';
|
|
342
270
|
}
|
|
343
271
|
}
|
|
344
272
|
}
|
|
345
273
|
async renderStackContent(stack) {
|
|
346
|
-
if (
|
|
274
|
+
if (stack.element.container.debugRender) {
|
|
347
275
|
debugger;
|
|
348
276
|
}
|
|
277
|
+
const signal = this.options.signal;
|
|
349
278
|
// https://www.w3.org/TR/css-position-3/#painting-order
|
|
350
279
|
// 1. the background and borders of the element forming the stacking context.
|
|
351
280
|
await this.renderNodeBackgroundAndBorders(stack.element);
|
|
352
281
|
// 2. the child stacking contexts with negative stack levels (most negative first).
|
|
353
282
|
for (const child of stack.negativeZIndex) {
|
|
283
|
+
if (signal?.aborted)
|
|
284
|
+
throw new DOMException('The operation was aborted.', 'AbortError');
|
|
354
285
|
await this.renderStack(child);
|
|
355
286
|
}
|
|
356
287
|
// 3. For all its in-flow, non-positioned, block-level descendants in tree order:
|
|
288
|
+
if (signal?.aborted)
|
|
289
|
+
throw new DOMException('The operation was aborted.', 'AbortError');
|
|
357
290
|
await this.renderNodeContent(stack.element);
|
|
358
291
|
for (const child of stack.nonInlineLevel) {
|
|
359
292
|
await this.renderNode(child);
|
|
@@ -363,10 +296,14 @@ class CanvasRenderer extends renderer_1.Renderer {
|
|
|
363
296
|
// which actually create a new stacking context should be considered part of the parent stacking context,
|
|
364
297
|
// not this new one.
|
|
365
298
|
for (const child of stack.nonPositionedFloats) {
|
|
299
|
+
if (signal?.aborted)
|
|
300
|
+
throw new DOMException('The operation was aborted.', 'AbortError');
|
|
366
301
|
await this.renderStack(child);
|
|
367
302
|
}
|
|
368
303
|
// 5. the in-flow, inline-level, non-positioned descendants, including inline tables and inline blocks.
|
|
369
304
|
for (const child of stack.nonPositionedInlineLevel) {
|
|
305
|
+
if (signal?.aborted)
|
|
306
|
+
throw new DOMException('The operation was aborted.', 'AbortError');
|
|
370
307
|
await this.renderStack(child);
|
|
371
308
|
}
|
|
372
309
|
for (const child of stack.inlineLevel) {
|
|
@@ -383,11 +320,15 @@ class CanvasRenderer extends renderer_1.Renderer {
|
|
|
383
320
|
//
|
|
384
321
|
// All transform descendants with transform other than none
|
|
385
322
|
for (const child of stack.zeroOrAutoZIndexOrTransformedOrOpacity) {
|
|
323
|
+
if (signal?.aborted)
|
|
324
|
+
throw new DOMException('The operation was aborted.', 'AbortError');
|
|
386
325
|
await this.renderStack(child);
|
|
387
326
|
}
|
|
388
327
|
// 7. Stacking contexts formed by positioned descendants with z-indices greater than or equal to 1 in z-index
|
|
389
328
|
// order (smallest first) then tree order.
|
|
390
329
|
for (const child of stack.positiveZIndex) {
|
|
330
|
+
if (signal?.aborted)
|
|
331
|
+
throw new DOMException('The operation was aborted.', 'AbortError');
|
|
391
332
|
await this.renderStack(child);
|
|
392
333
|
}
|
|
393
334
|
}
|
|
@@ -405,23 +346,10 @@ class CanvasRenderer extends renderer_1.Renderer {
|
|
|
405
346
|
this.ctx.closePath();
|
|
406
347
|
}
|
|
407
348
|
path(paths) {
|
|
408
|
-
this.ctx
|
|
409
|
-
this.formatPath(paths);
|
|
410
|
-
this.ctx.closePath();
|
|
349
|
+
(0, canvas_path_1.createCanvasPath)(this.ctx, paths);
|
|
411
350
|
}
|
|
412
351
|
formatPath(paths) {
|
|
413
|
-
|
|
414
|
-
const start = (0, bezier_curve_1.isBezierCurve)(point) ? point.start : point;
|
|
415
|
-
if (index === 0) {
|
|
416
|
-
this.ctx.moveTo(start.x, start.y);
|
|
417
|
-
}
|
|
418
|
-
else {
|
|
419
|
-
this.ctx.lineTo(start.x, start.y);
|
|
420
|
-
}
|
|
421
|
-
if ((0, bezier_curve_1.isBezierCurve)(point)) {
|
|
422
|
-
this.ctx.bezierCurveTo(point.startControl.x, point.startControl.y, point.endControl.x, point.endControl.y, point.end.x, point.end.y);
|
|
423
|
-
}
|
|
424
|
-
});
|
|
352
|
+
(0, canvas_path_1.formatCanvasPath)(this.ctx, paths);
|
|
425
353
|
}
|
|
426
354
|
async renderNodeBackgroundAndBorders(paint) {
|
|
427
355
|
this.effectsRenderer.applyEffects(paint.getEffects(2 /* EffectTarget.BACKGROUND_BORDERS */));
|
|
@@ -536,4 +464,3 @@ const canvasTextAlign = (textAlign) => {
|
|
|
536
464
|
return 'left';
|
|
537
465
|
}
|
|
538
466
|
};
|
|
539
|
-
//# sourceMappingURL=canvas-renderer.js.map
|
|
@@ -63,6 +63,9 @@ class EffectsRenderer {
|
|
|
63
63
|
// Clip-path: delegate shape drawing (beginPath … clip()) to the effect.
|
|
64
64
|
effect.applyClip(this.ctx);
|
|
65
65
|
}
|
|
66
|
+
else if ((0, effects_1.isBlendEffect)(effect)) {
|
|
67
|
+
this.ctx.globalCompositeOperation = effect.compositeOperation;
|
|
68
|
+
}
|
|
66
69
|
this.activeEffects.push(effect);
|
|
67
70
|
}
|
|
68
71
|
/**
|
|
@@ -91,4 +94,3 @@ class EffectsRenderer {
|
|
|
91
94
|
}
|
|
92
95
|
}
|
|
93
96
|
exports.EffectsRenderer = EffectsRenderer;
|
|
94
|
-
//# sourceMappingURL=effects-renderer.js.map
|
|
@@ -1,15 +1,14 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.ForeignObjectRenderer = void 0;
|
|
4
4
|
const features_1 = require("../../core/features");
|
|
5
5
|
const color_utilities_1 = require("../../css/types/color-utilities");
|
|
6
|
-
|
|
7
|
-
class ForeignObjectRenderer extends renderer_1.Renderer {
|
|
6
|
+
class ForeignObjectRenderer {
|
|
8
7
|
constructor(context, options) {
|
|
9
|
-
|
|
8
|
+
this.context = context;
|
|
9
|
+
this.options = options;
|
|
10
10
|
this.canvas = options.canvas ? options.canvas : document.createElement('canvas');
|
|
11
11
|
this.ctx = this.canvas.getContext('2d');
|
|
12
|
-
this.options = options;
|
|
13
12
|
this.canvas.width = Math.floor(options.width * options.scale);
|
|
14
13
|
this.canvas.height = Math.floor(options.height * options.scale);
|
|
15
14
|
this.canvas.style.width = `${options.width}px`;
|
|
@@ -19,8 +18,11 @@ class ForeignObjectRenderer extends renderer_1.Renderer {
|
|
|
19
18
|
this.context.logger.debug(`EXPERIMENTAL ForeignObject renderer initialized (${options.width}x${options.height} at ${options.x},${options.y}) with scale ${options.scale}`);
|
|
20
19
|
}
|
|
21
20
|
async render(element) {
|
|
21
|
+
if (this.options.signal?.aborted) {
|
|
22
|
+
throw new DOMException('The operation was aborted.', 'AbortError');
|
|
23
|
+
}
|
|
22
24
|
const svg = (0, features_1.createForeignObjectSVG)(this.options.width * this.options.scale, this.options.height * this.options.scale, this.options.scale, this.options.scale, element);
|
|
23
|
-
const img = await (0,
|
|
25
|
+
const img = await (0, features_1.loadSerializedSVG)(svg);
|
|
24
26
|
if (this.options.backgroundColor) {
|
|
25
27
|
this.ctx.fillStyle = (0, color_utilities_1.asString)(this.options.backgroundColor);
|
|
26
28
|
this.ctx.fillRect(0, 0, this.options.width * this.options.scale, this.options.height * this.options.scale);
|
|
@@ -30,13 +32,3 @@ class ForeignObjectRenderer extends renderer_1.Renderer {
|
|
|
30
32
|
}
|
|
31
33
|
}
|
|
32
34
|
exports.ForeignObjectRenderer = ForeignObjectRenderer;
|
|
33
|
-
const loadSerializedSVG = (svg) => new Promise((resolve, reject) => {
|
|
34
|
-
const img = new Image();
|
|
35
|
-
img.onload = () => {
|
|
36
|
-
resolve(img);
|
|
37
|
-
};
|
|
38
|
-
img.onerror = reject;
|
|
39
|
-
img.src = `data:image/svg+xml;charset=utf-8,${encodeURIComponent(new XMLSerializer().serializeToString(svg))}`;
|
|
40
|
-
});
|
|
41
|
-
exports.loadSerializedSVG = loadSerializedSVG;
|
|
42
|
-
//# sourceMappingURL=foreignobject-renderer.js.map
|
|
@@ -16,6 +16,7 @@ exports.TextRenderer = exports.hasCJKCharacters = void 0;
|
|
|
16
16
|
const text_1 = require("../../css/layout/text");
|
|
17
17
|
const color_utilities_1 = require("../../css/types/color-utilities");
|
|
18
18
|
const parser_1 = require("../../css/syntax/parser");
|
|
19
|
+
const writing_mode_1 = require("../../css/property-descriptors/writing-mode");
|
|
19
20
|
// iOS font fix - see https://github.com/niklasvh/html2canvas/pull/2645
|
|
20
21
|
const iOSBrokenFonts = ['-apple-system', 'system-ui'];
|
|
21
22
|
/**
|
|
@@ -79,6 +80,10 @@ const fixIOSSystemFonts = (fontFamilies) => {
|
|
|
79
80
|
}
|
|
80
81
|
return fontFamilies;
|
|
81
82
|
};
|
|
83
|
+
const getTextStrokeLineJoin = () => {
|
|
84
|
+
const currentWindow = typeof window !== 'undefined' ? window : undefined;
|
|
85
|
+
return currentWindow?.chrome ? 'miter' : 'round';
|
|
86
|
+
};
|
|
82
87
|
/**
|
|
83
88
|
* Text Renderer
|
|
84
89
|
*
|
|
@@ -106,7 +111,11 @@ class TextRenderer {
|
|
|
106
111
|
* call (fillText or strokeText), allowing fill and stroke paths to share one
|
|
107
112
|
* implementation.
|
|
108
113
|
*/
|
|
109
|
-
iterateLettersWithLetterSpacing(text, letterSpacing, baseline, renderFn) {
|
|
114
|
+
iterateLettersWithLetterSpacing(text, letterSpacing, baseline, writingMode, renderFn) {
|
|
115
|
+
if ((0, writing_mode_1.isVerticalWritingMode)(writingMode)) {
|
|
116
|
+
this.iterateVerticalGlyphs(text, letterSpacing, baseline, writingMode, renderFn);
|
|
117
|
+
return;
|
|
118
|
+
}
|
|
110
119
|
const letters = (0, text_1.segmentGraphemes)(text.text);
|
|
111
120
|
const y = text.bounds.top + baseline;
|
|
112
121
|
let left = text.bounds.left;
|
|
@@ -123,21 +132,92 @@ class TextRenderer {
|
|
|
123
132
|
left += this.ctx.measureText(letter).width + letterSpacing;
|
|
124
133
|
}
|
|
125
134
|
}
|
|
135
|
+
iterateVerticalGlyphs(text, letterSpacing, baseline, writingMode, renderFn) {
|
|
136
|
+
const letters = (0, text_1.segmentGraphemes)(text.text);
|
|
137
|
+
let top = text.bounds.top;
|
|
138
|
+
for (const letter of letters) {
|
|
139
|
+
if ((0, writing_mode_1.isSidewaysWritingMode)(writingMode) || (!(0, exports.hasCJKCharacters)(letter) && letter.trim().length > 0)) {
|
|
140
|
+
this.ctx.save();
|
|
141
|
+
this.ctx.translate(text.bounds.left + baseline, top);
|
|
142
|
+
this.ctx.rotate(writingMode === 4 /* WRITING_MODE.SIDEWAYS_LR */ ? -Math.PI / 2 : Math.PI / 2);
|
|
143
|
+
renderFn(letter, 0, 0);
|
|
144
|
+
this.ctx.restore();
|
|
145
|
+
}
|
|
146
|
+
else {
|
|
147
|
+
const savedBaseline = this.ctx.textBaseline;
|
|
148
|
+
if ((0, exports.hasCJKCharacters)(letter)) {
|
|
149
|
+
this.ctx.textBaseline = 'ideographic';
|
|
150
|
+
}
|
|
151
|
+
renderFn(letter, text.bounds.left, top + baseline);
|
|
152
|
+
this.ctx.textBaseline = savedBaseline;
|
|
153
|
+
}
|
|
154
|
+
top += this.ctx.measureText(letter).width + letterSpacing;
|
|
155
|
+
}
|
|
156
|
+
}
|
|
126
157
|
/**
|
|
127
158
|
* Render text with letter-spacing applied (fill pass).
|
|
128
159
|
* When letterSpacing is 0 the whole string is drawn in one call; otherwise each
|
|
129
160
|
* grapheme is drawn individually so spacing and CJK baseline are applied correctly.
|
|
130
161
|
*/
|
|
131
|
-
renderTextWithLetterSpacing(text, letterSpacing, baseline) {
|
|
132
|
-
|
|
162
|
+
renderTextWithLetterSpacing(text, letterSpacing, baseline, writingMode = 0 /* WRITING_MODE.HORIZONTAL_TB */) {
|
|
163
|
+
this.renderFillText(text, letterSpacing, baseline, writingMode);
|
|
164
|
+
}
|
|
165
|
+
canRenderWholeText(letterSpacing, writingMode) {
|
|
166
|
+
return letterSpacing === 0 && !(0, writing_mode_1.isVerticalWritingMode)(writingMode);
|
|
167
|
+
}
|
|
168
|
+
renderFillText(text, letterSpacing, baseline, writingMode) {
|
|
169
|
+
if (this.canRenderWholeText(letterSpacing, writingMode)) {
|
|
133
170
|
this.ctx.fillText(text.text, text.bounds.left, text.bounds.top + baseline);
|
|
134
171
|
}
|
|
135
172
|
else {
|
|
136
|
-
this.iterateLettersWithLetterSpacing(text, letterSpacing, baseline, (letter, x, y) => {
|
|
173
|
+
this.iterateLettersWithLetterSpacing(text, letterSpacing, baseline, writingMode, (letter, x, y) => {
|
|
137
174
|
this.ctx.fillText(letter, x, y);
|
|
138
175
|
});
|
|
139
176
|
}
|
|
140
177
|
}
|
|
178
|
+
renderStrokeText(text, letterSpacing, baseline, writingMode) {
|
|
179
|
+
if (this.canRenderWholeText(letterSpacing, writingMode)) {
|
|
180
|
+
this.ctx.strokeText(text.text, text.bounds.left, text.bounds.top + baseline);
|
|
181
|
+
}
|
|
182
|
+
else {
|
|
183
|
+
this.iterateLettersWithLetterSpacing(text, letterSpacing, baseline, writingMode, (letter, x, y) => {
|
|
184
|
+
this.ctx.strokeText(letter, x, y);
|
|
185
|
+
});
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
renderTextStrokeWithStyle(text, styles) {
|
|
189
|
+
if (!styles.webkitTextStrokeWidth || !text.text.trim().length) {
|
|
190
|
+
return;
|
|
191
|
+
}
|
|
192
|
+
this.ctx.strokeStyle = (0, color_utilities_1.asString)(styles.webkitTextStrokeColor);
|
|
193
|
+
this.ctx.lineWidth = styles.webkitTextStrokeWidth;
|
|
194
|
+
this.ctx.lineJoin = getTextStrokeLineJoin();
|
|
195
|
+
this.renderStrokeText(text, styles.letterSpacing, styles.fontSize.number, styles.writingMode);
|
|
196
|
+
this.ctx.strokeStyle = '';
|
|
197
|
+
this.ctx.lineWidth = 0;
|
|
198
|
+
this.ctx.lineJoin = 'miter';
|
|
199
|
+
}
|
|
200
|
+
renderTextFillWithShadows(text, styles) {
|
|
201
|
+
this.ctx.fillStyle = (0, color_utilities_1.asString)(styles.color);
|
|
202
|
+
this.renderTextWithLetterSpacing(text, styles.letterSpacing, styles.fontSize.number, styles.writingMode);
|
|
203
|
+
const textShadows = styles.textShadow;
|
|
204
|
+
if (textShadows.length && text.text.trim().length) {
|
|
205
|
+
textShadows
|
|
206
|
+
.slice(0)
|
|
207
|
+
.reverse()
|
|
208
|
+
.forEach((textShadow) => {
|
|
209
|
+
this.ctx.shadowColor = (0, color_utilities_1.asString)(textShadow.color);
|
|
210
|
+
this.ctx.shadowOffsetX = textShadow.offsetX.number * this.options.scale;
|
|
211
|
+
this.ctx.shadowOffsetY = textShadow.offsetY.number * this.options.scale;
|
|
212
|
+
this.ctx.shadowBlur = textShadow.blur.number;
|
|
213
|
+
this.renderTextWithLetterSpacing(text, styles.letterSpacing, styles.fontSize.number, styles.writingMode);
|
|
214
|
+
});
|
|
215
|
+
this.ctx.shadowColor = '';
|
|
216
|
+
this.ctx.shadowOffsetX = 0;
|
|
217
|
+
this.ctx.shadowOffsetY = 0;
|
|
218
|
+
this.ctx.shadowBlur = 0;
|
|
219
|
+
}
|
|
220
|
+
}
|
|
141
221
|
/**
|
|
142
222
|
* Helper method to render text with paint order support
|
|
143
223
|
* Reduces code duplication in line-clamp and normal rendering
|
|
@@ -147,24 +227,10 @@ class TextRenderer {
|
|
|
147
227
|
switch (paintOrderLayer) {
|
|
148
228
|
case 0 /* PAINT_ORDER_LAYER.FILL */:
|
|
149
229
|
this.ctx.fillStyle = (0, color_utilities_1.asString)(styles.color);
|
|
150
|
-
this.renderTextWithLetterSpacing(textBound, styles.letterSpacing, styles.fontSize.number);
|
|
230
|
+
this.renderTextWithLetterSpacing(textBound, styles.letterSpacing, styles.fontSize.number, styles.writingMode);
|
|
151
231
|
break;
|
|
152
232
|
case 1 /* PAINT_ORDER_LAYER.STROKE */:
|
|
153
|
-
|
|
154
|
-
this.ctx.strokeStyle = (0, color_utilities_1.asString)(styles.webkitTextStrokeColor);
|
|
155
|
-
this.ctx.lineWidth = styles.webkitTextStrokeWidth;
|
|
156
|
-
this.ctx.lineJoin =
|
|
157
|
-
typeof window !== 'undefined' && !!window.chrome ? 'miter' : 'round';
|
|
158
|
-
if (styles.letterSpacing === 0) {
|
|
159
|
-
this.ctx.strokeText(textBound.text, textBound.bounds.left, textBound.bounds.top + styles.fontSize.number);
|
|
160
|
-
}
|
|
161
|
-
else {
|
|
162
|
-
this.iterateLettersWithLetterSpacing(textBound, styles.letterSpacing, styles.fontSize.number, (letter, x, y) => this.ctx.strokeText(letter, x, y));
|
|
163
|
-
}
|
|
164
|
-
this.ctx.strokeStyle = '';
|
|
165
|
-
this.ctx.lineWidth = 0;
|
|
166
|
-
this.ctx.lineJoin = 'miter';
|
|
167
|
-
}
|
|
233
|
+
this.renderTextStrokeWithStyle(textBound, styles);
|
|
168
234
|
break;
|
|
169
235
|
}
|
|
170
236
|
});
|
|
@@ -395,29 +461,10 @@ class TextRenderer {
|
|
|
395
461
|
switch (paintOrderLayer) {
|
|
396
462
|
case 0 /* PAINT_ORDER_LAYER.FILL */:
|
|
397
463
|
this.ctx.fillStyle = (0, color_utilities_1.asString)(styles.color);
|
|
398
|
-
|
|
399
|
-
this.ctx.fillText(truncatedText, firstBound.bounds.left, firstBound.bounds.top + styles.fontSize.number);
|
|
400
|
-
}
|
|
401
|
-
else {
|
|
402
|
-
this.iterateLettersWithLetterSpacing(truncatedBounds, styles.letterSpacing, styles.fontSize.number, (letter, x, y) => this.ctx.fillText(letter, x, y));
|
|
403
|
-
}
|
|
464
|
+
this.renderTextWithLetterSpacing(truncatedBounds, styles.letterSpacing, styles.fontSize.number, styles.writingMode);
|
|
404
465
|
break;
|
|
405
466
|
case 1 /* PAINT_ORDER_LAYER.STROKE */:
|
|
406
|
-
|
|
407
|
-
this.ctx.strokeStyle = (0, color_utilities_1.asString)(styles.webkitTextStrokeColor);
|
|
408
|
-
this.ctx.lineWidth = styles.webkitTextStrokeWidth;
|
|
409
|
-
this.ctx.lineJoin =
|
|
410
|
-
typeof window !== 'undefined' && !!window.chrome ? 'miter' : 'round';
|
|
411
|
-
if (styles.letterSpacing === 0) {
|
|
412
|
-
this.ctx.strokeText(truncatedText, firstBound.bounds.left, firstBound.bounds.top + styles.fontSize.number);
|
|
413
|
-
}
|
|
414
|
-
else {
|
|
415
|
-
this.iterateLettersWithLetterSpacing(truncatedBounds, styles.letterSpacing, styles.fontSize.number, (letter, x, y) => this.ctx.strokeText(letter, x, y));
|
|
416
|
-
}
|
|
417
|
-
this.ctx.strokeStyle = '';
|
|
418
|
-
this.ctx.lineWidth = 0;
|
|
419
|
-
this.ctx.lineJoin = 'miter';
|
|
420
|
-
}
|
|
467
|
+
this.renderTextStrokeWithStyle(truncatedBounds, styles);
|
|
421
468
|
break;
|
|
422
469
|
}
|
|
423
470
|
});
|
|
@@ -466,53 +513,11 @@ class TextRenderer {
|
|
|
466
513
|
paintOrder.forEach((paintOrderLayer) => {
|
|
467
514
|
switch (paintOrderLayer) {
|
|
468
515
|
case 0 /* PAINT_ORDER_LAYER.FILL */: {
|
|
469
|
-
this.
|
|
470
|
-
if (styles.letterSpacing === 0) {
|
|
471
|
-
this.ctx.fillText(truncatedText, firstBound.bounds.left, firstBound.bounds.top + styles.fontSize.number);
|
|
472
|
-
}
|
|
473
|
-
else {
|
|
474
|
-
this.iterateLettersWithLetterSpacing(truncatedBounds, styles.letterSpacing, styles.fontSize.number, (letter, x, y) => this.ctx.fillText(letter, x, y));
|
|
475
|
-
}
|
|
476
|
-
const textShadows = styles.textShadow;
|
|
477
|
-
if (textShadows.length && truncatedText.trim().length) {
|
|
478
|
-
textShadows
|
|
479
|
-
.slice(0)
|
|
480
|
-
.reverse()
|
|
481
|
-
.forEach((textShadow) => {
|
|
482
|
-
this.ctx.shadowColor = (0, color_utilities_1.asString)(textShadow.color);
|
|
483
|
-
this.ctx.shadowOffsetX = textShadow.offsetX.number * this.options.scale;
|
|
484
|
-
this.ctx.shadowOffsetY = textShadow.offsetY.number * this.options.scale;
|
|
485
|
-
this.ctx.shadowBlur = textShadow.blur.number;
|
|
486
|
-
if (styles.letterSpacing === 0) {
|
|
487
|
-
this.ctx.fillText(truncatedText, firstBound.bounds.left, firstBound.bounds.top + styles.fontSize.number);
|
|
488
|
-
}
|
|
489
|
-
else {
|
|
490
|
-
this.iterateLettersWithLetterSpacing(truncatedBounds, styles.letterSpacing, styles.fontSize.number, (letter, x, y) => this.ctx.fillText(letter, x, y));
|
|
491
|
-
}
|
|
492
|
-
});
|
|
493
|
-
this.ctx.shadowColor = '';
|
|
494
|
-
this.ctx.shadowOffsetX = 0;
|
|
495
|
-
this.ctx.shadowOffsetY = 0;
|
|
496
|
-
this.ctx.shadowBlur = 0;
|
|
497
|
-
}
|
|
516
|
+
this.renderTextFillWithShadows(truncatedBounds, styles);
|
|
498
517
|
break;
|
|
499
518
|
}
|
|
500
519
|
case 1 /* PAINT_ORDER_LAYER.STROKE */:
|
|
501
|
-
|
|
502
|
-
this.ctx.strokeStyle = (0, color_utilities_1.asString)(styles.webkitTextStrokeColor);
|
|
503
|
-
this.ctx.lineWidth = styles.webkitTextStrokeWidth;
|
|
504
|
-
this.ctx.lineJoin =
|
|
505
|
-
typeof window !== 'undefined' && !!window.chrome ? 'miter' : 'round';
|
|
506
|
-
if (styles.letterSpacing === 0) {
|
|
507
|
-
this.ctx.strokeText(truncatedText, firstBound.bounds.left, firstBound.bounds.top + styles.fontSize.number);
|
|
508
|
-
}
|
|
509
|
-
else {
|
|
510
|
-
this.iterateLettersWithLetterSpacing(truncatedBounds, styles.letterSpacing, styles.fontSize.number, (letter, x, y) => this.ctx.strokeText(letter, x, y));
|
|
511
|
-
}
|
|
512
|
-
this.ctx.strokeStyle = '';
|
|
513
|
-
this.ctx.lineWidth = 0;
|
|
514
|
-
this.ctx.lineJoin = 'miter';
|
|
515
|
-
}
|
|
520
|
+
this.renderTextStrokeWithStyle(truncatedBounds, styles);
|
|
516
521
|
break;
|
|
517
522
|
}
|
|
518
523
|
});
|
|
@@ -523,47 +528,14 @@ class TextRenderer {
|
|
|
523
528
|
paintOrder.forEach((paintOrderLayer) => {
|
|
524
529
|
switch (paintOrderLayer) {
|
|
525
530
|
case 0 /* PAINT_ORDER_LAYER.FILL */: {
|
|
526
|
-
this.
|
|
527
|
-
this.renderTextWithLetterSpacing(text, styles.letterSpacing, styles.fontSize.number);
|
|
528
|
-
const textShadows = styles.textShadow;
|
|
529
|
-
if (textShadows.length && text.text.trim().length) {
|
|
530
|
-
textShadows
|
|
531
|
-
.slice(0)
|
|
532
|
-
.reverse()
|
|
533
|
-
.forEach((textShadow) => {
|
|
534
|
-
this.ctx.shadowColor = (0, color_utilities_1.asString)(textShadow.color);
|
|
535
|
-
this.ctx.shadowOffsetX = textShadow.offsetX.number * this.options.scale;
|
|
536
|
-
this.ctx.shadowOffsetY = textShadow.offsetY.number * this.options.scale;
|
|
537
|
-
this.ctx.shadowBlur = textShadow.blur.number;
|
|
538
|
-
this.renderTextWithLetterSpacing(text, styles.letterSpacing, styles.fontSize.number);
|
|
539
|
-
});
|
|
540
|
-
this.ctx.shadowColor = '';
|
|
541
|
-
this.ctx.shadowOffsetX = 0;
|
|
542
|
-
this.ctx.shadowOffsetY = 0;
|
|
543
|
-
this.ctx.shadowBlur = 0;
|
|
544
|
-
}
|
|
531
|
+
this.renderTextFillWithShadows(text, styles);
|
|
545
532
|
if (styles.textDecorationLine.length) {
|
|
546
533
|
this.renderTextDecoration(text.bounds, styles);
|
|
547
534
|
}
|
|
548
535
|
break;
|
|
549
536
|
}
|
|
550
537
|
case 1 /* PAINT_ORDER_LAYER.STROKE */: {
|
|
551
|
-
|
|
552
|
-
this.ctx.strokeStyle = (0, color_utilities_1.asString)(styles.webkitTextStrokeColor);
|
|
553
|
-
this.ctx.lineWidth = styles.webkitTextStrokeWidth;
|
|
554
|
-
this.ctx.lineJoin =
|
|
555
|
-
typeof window !== 'undefined' && !!window.chrome ? 'miter' : 'round';
|
|
556
|
-
const baseline = styles.fontSize.number;
|
|
557
|
-
if (styles.letterSpacing === 0) {
|
|
558
|
-
this.ctx.strokeText(text.text, text.bounds.left, text.bounds.top + baseline);
|
|
559
|
-
}
|
|
560
|
-
else {
|
|
561
|
-
this.iterateLettersWithLetterSpacing(text, styles.letterSpacing, baseline, (letter, x, y) => this.ctx.strokeText(letter, x, y));
|
|
562
|
-
}
|
|
563
|
-
this.ctx.strokeStyle = '';
|
|
564
|
-
this.ctx.lineWidth = 0;
|
|
565
|
-
this.ctx.lineJoin = 'miter';
|
|
566
|
-
}
|
|
538
|
+
this.renderTextStrokeWithStyle(text, styles);
|
|
567
539
|
break;
|
|
568
540
|
}
|
|
569
541
|
}
|
|
@@ -572,4 +544,3 @@ class TextRenderer {
|
|
|
572
544
|
}
|
|
573
545
|
}
|
|
574
546
|
exports.TextRenderer = TextRenderer;
|
|
575
|
-
//# sourceMappingURL=text-renderer.js.map
|