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
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.isClipPathEffect = exports.isOpacityEffect = exports.isClipEffect = exports.isTransformEffect = exports.ClipPathEffect = exports.OpacityEffect = exports.ClipEffect = exports.TransformEffect = void 0;
|
|
3
|
+
exports.isBlendEffect = exports.isClipPathEffect = exports.isOpacityEffect = exports.isClipEffect = exports.isTransformEffect = exports.BlendEffect = exports.ClipPathEffect = exports.OpacityEffect = exports.ClipEffect = exports.TransformEffect = void 0;
|
|
4
4
|
class TransformEffect {
|
|
5
5
|
constructor(offsetX, offsetY, matrix) {
|
|
6
6
|
this.offsetX = offsetX;
|
|
@@ -41,6 +41,14 @@ class ClipPathEffect {
|
|
|
41
41
|
}
|
|
42
42
|
}
|
|
43
43
|
exports.ClipPathEffect = ClipPathEffect;
|
|
44
|
+
class BlendEffect {
|
|
45
|
+
constructor(compositeOperation) {
|
|
46
|
+
this.compositeOperation = compositeOperation;
|
|
47
|
+
this.type = 4 /* EffectType.BLEND */;
|
|
48
|
+
this.target = 2 /* EffectTarget.BACKGROUND_BORDERS */ | 4 /* EffectTarget.CONTENT */;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
exports.BlendEffect = BlendEffect;
|
|
44
52
|
const isTransformEffect = (effect) => effect.type === 0 /* EffectType.TRANSFORM */;
|
|
45
53
|
exports.isTransformEffect = isTransformEffect;
|
|
46
54
|
const isClipEffect = (effect) => effect.type === 1 /* EffectType.CLIP */;
|
|
@@ -49,4 +57,5 @@ const isOpacityEffect = (effect) => effect.type === 2 /* EffectType.OPACITY */;
|
|
|
49
57
|
exports.isOpacityEffect = isOpacityEffect;
|
|
50
58
|
const isClipPathEffect = (effect) => effect.type === 3 /* EffectType.CLIP_PATH */;
|
|
51
59
|
exports.isClipPathEffect = isClipPathEffect;
|
|
52
|
-
|
|
60
|
+
const isBlendEffect = (effect) => effect.type === 4 /* EffectType.BLEND */;
|
|
61
|
+
exports.isBlendEffect = isBlendEffect;
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.calculateObjectFitRendering = void 0;
|
|
4
|
+
const calculateObjectFitRendering = (intrinsicWidth, intrinsicHeight, box, objectFit) => {
|
|
5
|
+
let sx = 0;
|
|
6
|
+
let sy = 0;
|
|
7
|
+
let sw = intrinsicWidth;
|
|
8
|
+
let sh = intrinsicHeight;
|
|
9
|
+
let dx = box.left;
|
|
10
|
+
let dy = box.top;
|
|
11
|
+
let dw = box.width;
|
|
12
|
+
let dh = box.height;
|
|
13
|
+
const boxRatio = dw / dh;
|
|
14
|
+
const imgRatio = sw / sh;
|
|
15
|
+
if (objectFit === 2 /* OBJECT_FIT.CONTAIN */) {
|
|
16
|
+
if (imgRatio > boxRatio) {
|
|
17
|
+
dh = dw / imgRatio;
|
|
18
|
+
dy += (box.height - dh) / 2;
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
dw = dh * imgRatio;
|
|
22
|
+
dx += (box.width - dw) / 2;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
else if (objectFit === 4 /* OBJECT_FIT.COVER */) {
|
|
26
|
+
if (imgRatio > boxRatio) {
|
|
27
|
+
sw = sh * boxRatio;
|
|
28
|
+
sx += (intrinsicWidth - sw) / 2;
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
sh = sw / boxRatio;
|
|
32
|
+
sy += (intrinsicHeight - sh) / 2;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
else if (objectFit === 8 /* OBJECT_FIT.NONE */) {
|
|
36
|
+
if (sw > dw) {
|
|
37
|
+
sx += (sw - dw) / 2;
|
|
38
|
+
sw = dw;
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
dx += (dw - sw) / 2;
|
|
42
|
+
dw = sw;
|
|
43
|
+
}
|
|
44
|
+
if (sh > dh) {
|
|
45
|
+
sy += (sh - dh) / 2;
|
|
46
|
+
sh = dh;
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
dy += (dh - sh) / 2;
|
|
50
|
+
dh = sh;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
else if (objectFit === 16 /* OBJECT_FIT.SCALE_DOWN */) {
|
|
54
|
+
const containW = imgRatio > boxRatio ? dw : dh * imgRatio;
|
|
55
|
+
const noneW = sw > dw ? sw : dw;
|
|
56
|
+
if (containW < noneW) {
|
|
57
|
+
if (imgRatio > boxRatio) {
|
|
58
|
+
dh = dw / imgRatio;
|
|
59
|
+
dy += (box.height - dh) / 2;
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
dw = dh * imgRatio;
|
|
63
|
+
dx += (box.width - dw) / 2;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
if (sw > dw) {
|
|
68
|
+
sx += (sw - dw) / 2;
|
|
69
|
+
sw = dw;
|
|
70
|
+
}
|
|
71
|
+
else {
|
|
72
|
+
dx += (dw - sw) / 2;
|
|
73
|
+
dw = sw;
|
|
74
|
+
}
|
|
75
|
+
if (sh > dh) {
|
|
76
|
+
sy += (sh - dh) / 2;
|
|
77
|
+
sh = dh;
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
dy += (dh - sh) / 2;
|
|
81
|
+
dh = sh;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
return { sx, sy, sw, sh, dx, dy, dw, dh };
|
|
86
|
+
};
|
|
87
|
+
exports.calculateObjectFitRendering = calculateObjectFitRendering;
|
package/dist/lib/render/path.js
CHANGED
|
@@ -9,6 +9,7 @@ const ol_element_container_1 = require("../dom/elements/ol-element-container");
|
|
|
9
9
|
const li_element_container_1 = require("../dom/elements/li-element-container");
|
|
10
10
|
const counter_1 = require("../css/types/functions/counter");
|
|
11
11
|
const length_percentage_1 = require("../css/types/length-percentage");
|
|
12
|
+
const mix_blend_mode_1 = require("../css/property-descriptors/mix-blend-mode");
|
|
12
13
|
class StackingContext {
|
|
13
14
|
constructor(container) {
|
|
14
15
|
this.element = container;
|
|
@@ -50,7 +51,7 @@ class ElementPaint {
|
|
|
50
51
|
const matrix = this.container.styles.transform;
|
|
51
52
|
this.effects.push(new effects_1.TransformEffect(offsetX, offsetY, matrix));
|
|
52
53
|
}
|
|
53
|
-
if (this.container.styles
|
|
54
|
+
if (hasOverflowClip(this.container.styles)) {
|
|
54
55
|
const borderBox = (0, bound_curves_1.calculateBorderBoxPath)(this.curves);
|
|
55
56
|
const paddingBox = (0, bound_curves_1.calculatePaddingBoxPath)(this.curves);
|
|
56
57
|
if ((0, path_1.equalPath)(borderBox, paddingBox)) {
|
|
@@ -67,6 +68,9 @@ class ElementPaint {
|
|
|
67
68
|
this.effects.push(clipPathEffect);
|
|
68
69
|
}
|
|
69
70
|
}
|
|
71
|
+
if (this.container.styles.mixBlendMode !== mix_blend_mode_1.MIX_BLEND_MODE.NORMAL) {
|
|
72
|
+
this.effects.push(new effects_1.BlendEffect(this.container.styles.mixBlendMode));
|
|
73
|
+
}
|
|
70
74
|
}
|
|
71
75
|
getEffects(target) {
|
|
72
76
|
let inFlow = [2 /* POSITION.ABSOLUTE */, 3 /* POSITION.FIXED */].indexOf(this.container.styles.position) === -1;
|
|
@@ -76,7 +80,7 @@ class ElementPaint {
|
|
|
76
80
|
const croplessEffects = parent.effects.filter((effect) => !(0, effects_1.isClipEffect)(effect));
|
|
77
81
|
if (inFlow || parent.container.styles.position !== 0 /* POSITION.STATIC */ || !parent.parent) {
|
|
78
82
|
inFlow = [2 /* POSITION.ABSOLUTE */, 3 /* POSITION.FIXED */].indexOf(parent.container.styles.position) === -1;
|
|
79
|
-
if (parent.container.styles
|
|
83
|
+
if (hasOverflowClip(parent.container.styles)) {
|
|
80
84
|
const borderBox = (0, bound_curves_1.calculateBorderBoxPath)(parent.curves);
|
|
81
85
|
const paddingBox = (0, bound_curves_1.calculatePaddingBoxPath)(parent.curves);
|
|
82
86
|
if (!(0, path_1.equalPath)(borderBox, paddingBox)) {
|
|
@@ -94,6 +98,7 @@ class ElementPaint {
|
|
|
94
98
|
}
|
|
95
99
|
}
|
|
96
100
|
exports.ElementPaint = ElementPaint;
|
|
101
|
+
const hasOverflowClip = (styles) => styles.overflowX !== 0 /* OVERFLOW.VISIBLE */ || styles.overflowY !== 0 /* OVERFLOW.VISIBLE */;
|
|
97
102
|
/**
|
|
98
103
|
* Resolve a `closest-side` or `farthest-side` shape-radius keyword to pixels
|
|
99
104
|
* for a single axis. Used by both `circle()` (per-axis) and `ellipse()`.
|
|
@@ -195,11 +200,15 @@ const buildClipPathEffect = (clipPath, bounds) => {
|
|
|
195
200
|
// by a preceding TransformEffect, so the path coordinates end up correctly in
|
|
196
201
|
// the element's transformed local space — matching browser behaviour.
|
|
197
202
|
const { d } = clipPath;
|
|
203
|
+
let cachedPath = null;
|
|
198
204
|
return new effects_1.ClipPathEffect((ctx) => {
|
|
199
205
|
try {
|
|
206
|
+
if (!cachedPath) {
|
|
207
|
+
cachedPath = new Path2D(d);
|
|
208
|
+
}
|
|
200
209
|
const savedTransform = ctx.getTransform();
|
|
201
210
|
ctx.translate(bLeft, bTop);
|
|
202
|
-
ctx.clip(
|
|
211
|
+
ctx.clip(cachedPath);
|
|
203
212
|
ctx.setTransform(savedTransform);
|
|
204
213
|
}
|
|
205
214
|
catch (_e) {
|
|
@@ -221,13 +230,13 @@ const buildClipPathEffect = (clipPath, bounds) => {
|
|
|
221
230
|
};
|
|
222
231
|
const parseStackTree = (parent, stackingContext, realStackingContext, listItems) => {
|
|
223
232
|
parent.container.elements.forEach((child) => {
|
|
224
|
-
const treatAsRealStackingContext =
|
|
225
|
-
const createsStackingContext =
|
|
233
|
+
const treatAsRealStackingContext = child.createsRealStackingContext;
|
|
234
|
+
const createsStackingContext = child.createsStackingContext;
|
|
226
235
|
const paintContainer = new ElementPaint(child, parent);
|
|
227
236
|
if ((0, bitwise_1.contains)(child.styles.display, 2048 /* DISPLAY.LIST_ITEM */)) {
|
|
228
237
|
listItems.push(paintContainer);
|
|
229
238
|
}
|
|
230
|
-
const listOwnerItems =
|
|
239
|
+
const listOwnerItems = child.isListOwner ? [] : listItems;
|
|
231
240
|
if (treatAsRealStackingContext || createsStackingContext) {
|
|
232
241
|
const parentStack = treatAsRealStackingContext || child.styles.isPositioned() ? realStackingContext : stackingContext;
|
|
233
242
|
const stack = new StackingContext(paintContainer);
|
|
@@ -284,7 +293,7 @@ const parseStackTree = (parent, stackingContext, realStackingContext, listItems)
|
|
|
284
293
|
}
|
|
285
294
|
parseStackTree(paintContainer, stackingContext, realStackingContext, listOwnerItems);
|
|
286
295
|
}
|
|
287
|
-
if (
|
|
296
|
+
if (child.isListOwner) {
|
|
288
297
|
processListItems(child, listOwnerItems);
|
|
289
298
|
}
|
|
290
299
|
});
|
|
@@ -312,4 +321,3 @@ const parseStackingContexts = (container) => {
|
|
|
312
321
|
return root;
|
|
313
322
|
};
|
|
314
323
|
exports.parseStackingContexts = parseStackingContexts;
|
|
315
|
-
//# sourceMappingURL=stacking-context.js.map
|
|
@@ -40,15 +40,14 @@ export declare class Cache {
|
|
|
40
40
|
constructor(context: Context, _options: ResourceOptions);
|
|
41
41
|
addImage(src: string): Promise<void>;
|
|
42
42
|
private _addImageInternal;
|
|
43
|
-
|
|
43
|
+
private withTimeout;
|
|
44
|
+
match(src: string): Promise<HTMLImageElement | HTMLCanvasElement | undefined> | undefined;
|
|
44
45
|
/**
|
|
45
|
-
* Set a value in cache with LRU eviction
|
|
46
|
+
* Set a value in cache with LRU eviction (O(1) via Map insertion order).
|
|
47
|
+
* Map preserves insertion order; delete+set on access moves items to the end.
|
|
48
|
+
* The first key in Map.keys() is always the least recently used.
|
|
46
49
|
*/
|
|
47
50
|
private set;
|
|
48
|
-
/**
|
|
49
|
-
* Evict least recently used entry
|
|
50
|
-
*/
|
|
51
|
-
private evictLRU;
|
|
52
51
|
/**
|
|
53
52
|
* Get cache size
|
|
54
53
|
*/
|
|
@@ -118,14 +118,3 @@ export declare class PerformanceMonitor {
|
|
|
118
118
|
*/
|
|
119
119
|
getActiveMetrics(): string[];
|
|
120
120
|
}
|
|
121
|
-
/**
|
|
122
|
-
* Create a no-op performance monitor for production
|
|
123
|
-
* Has minimal overhead when disabled
|
|
124
|
-
*/
|
|
125
|
-
export declare class NoOpPerformanceMonitor extends PerformanceMonitor {
|
|
126
|
-
constructor();
|
|
127
|
-
start(): void;
|
|
128
|
-
end(): undefined;
|
|
129
|
-
measure<T>(_name: string, fn: () => T): T;
|
|
130
|
-
measureAsync<T>(_name: string, fn: () => Promise<T>): Promise<T>;
|
|
131
|
-
}
|
|
@@ -27,6 +27,7 @@ import { transformOrigin } from './property-descriptors/transform-origin';
|
|
|
27
27
|
import { rotate } from './property-descriptors/rotate';
|
|
28
28
|
import { visibility } from './property-descriptors/visibility';
|
|
29
29
|
import { wordBreak } from './property-descriptors/word-break';
|
|
30
|
+
import { writingMode } from './property-descriptors/writing-mode';
|
|
30
31
|
import { zIndex } from './property-descriptors/z-index';
|
|
31
32
|
import { CSSValue } from './syntax/parser';
|
|
32
33
|
import { Color } from './types/color';
|
|
@@ -53,6 +54,7 @@ import { Context } from '../core/context';
|
|
|
53
54
|
import { objectFit } from './property-descriptors/object-fit';
|
|
54
55
|
import { textOverflow } from './property-descriptors/text-overflow';
|
|
55
56
|
import { imageRendering } from './property-descriptors/image-rendering';
|
|
57
|
+
import { MixBlendMode } from './property-descriptors/mix-blend-mode';
|
|
56
58
|
export declare class CSSParsedDeclaration {
|
|
57
59
|
animationDuration: ReturnType<typeof duration.parse>;
|
|
58
60
|
backgroundClip: ReturnType<typeof backgroundClip.parse>;
|
|
@@ -126,9 +128,12 @@ export declare class CSSParsedDeclaration {
|
|
|
126
128
|
webkitTextStrokeWidth: ReturnType<typeof webkitTextStrokeWidth.parse>;
|
|
127
129
|
webkitLineClamp: ReturnType<typeof webkitLineClamp.parse>;
|
|
128
130
|
wordBreak: ReturnType<typeof wordBreak.parse>;
|
|
131
|
+
writingMode: ReturnType<typeof writingMode.parse>;
|
|
129
132
|
zIndex: ReturnType<typeof zIndex.parse>;
|
|
130
133
|
objectFit: ReturnType<typeof objectFit.parse>;
|
|
131
134
|
imageRendering: ReturnType<typeof imageRendering.parse>;
|
|
135
|
+
mixBlendMode: MixBlendMode;
|
|
136
|
+
private static readonly standardProps;
|
|
132
137
|
constructor(context: Context, declaration: CSSStyleDeclaration);
|
|
133
138
|
isVisible(): boolean;
|
|
134
139
|
isTransparent(): boolean;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { IPropertyTypeValueDescriptor } from '../
|
|
1
|
+
import { IPropertyTypeValueDescriptor } from '../property-descriptor';
|
|
2
2
|
export declare const backgroundColor: IPropertyTypeValueDescriptor;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IPropertyListDescriptor } from '../
|
|
1
|
+
import { IPropertyListDescriptor } from '../property-descriptor';
|
|
2
2
|
import { LengthPercentageTuple } from '../types/length-percentage';
|
|
3
3
|
export type BackgroundPosition = BackgroundImagePosition[];
|
|
4
4
|
export type BackgroundImagePosition = LengthPercentageTuple;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IPropertyListDescriptor } from '../
|
|
1
|
+
import { IPropertyListDescriptor } from '../property-descriptor';
|
|
2
2
|
import { LengthPercentage } from '../types/length-percentage';
|
|
3
3
|
import { StringValueToken } from '../syntax/tokenizer';
|
|
4
4
|
export declare enum BACKGROUND_SIZE {
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IPropertyTypeValueDescriptor } from '../
|
|
1
|
+
import { IPropertyTypeValueDescriptor } from '../property-descriptor';
|
|
2
2
|
export declare const borderTopColor: IPropertyTypeValueDescriptor;
|
|
3
3
|
export declare const borderRightColor: IPropertyTypeValueDescriptor;
|
|
4
4
|
export declare const borderBottomColor: IPropertyTypeValueDescriptor;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IPropertyListDescriptor } from '../
|
|
1
|
+
import { IPropertyListDescriptor } from '../property-descriptor';
|
|
2
2
|
import { LengthPercentageTuple } from '../types/length-percentage';
|
|
3
3
|
export type BorderRadius = LengthPercentageTuple;
|
|
4
4
|
export declare const borderTopLeftRadius: IPropertyListDescriptor<BorderRadius>;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IPropertyValueDescriptor } from '../
|
|
1
|
+
import { IPropertyValueDescriptor } from '../property-descriptor';
|
|
2
2
|
export declare const borderTopWidth: IPropertyValueDescriptor<number>;
|
|
3
3
|
export declare const borderRightWidth: IPropertyValueDescriptor<number>;
|
|
4
4
|
export declare const borderBottomWidth: IPropertyValueDescriptor<number>;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { IPropertyTypeValueDescriptor } from '../
|
|
1
|
+
import { IPropertyTypeValueDescriptor } from '../property-descriptor';
|
|
2
2
|
export declare const color: IPropertyTypeValueDescriptor;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IPropertyListDescriptor } from '../
|
|
1
|
+
import { IPropertyListDescriptor } from '../property-descriptor';
|
|
2
2
|
import { CSSValue } from '../syntax/parser';
|
|
3
3
|
export type Content = CSSValue[];
|
|
4
4
|
export declare const content: IPropertyListDescriptor<Content>;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { IPropertyListDescriptor } from '../
|
|
1
|
+
import { IPropertyListDescriptor } from '../property-descriptor';
|
|
2
2
|
export declare const duration: IPropertyListDescriptor<number[]>;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IPropertyListDescriptor } from '../
|
|
1
|
+
import { IPropertyListDescriptor } from '../property-descriptor';
|
|
2
2
|
export type FONT_FAMILY = string;
|
|
3
3
|
export type FontFamily = FONT_FAMILY[];
|
|
4
4
|
export declare const fontFamily: IPropertyListDescriptor<FontFamily>;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { IPropertyTypeValueDescriptor } from '../
|
|
1
|
+
import { IPropertyTypeValueDescriptor } from '../property-descriptor';
|
|
2
2
|
export declare const fontSize: IPropertyTypeValueDescriptor;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { IPropertyListDescriptor } from '../
|
|
1
|
+
import { IPropertyListDescriptor } from '../property-descriptor';
|
|
2
2
|
export declare const fontVariant: IPropertyListDescriptor<string[]>;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { IPropertyValueDescriptor } from '../
|
|
1
|
+
import { IPropertyValueDescriptor } from '../property-descriptor';
|
|
2
2
|
export declare const fontWeight: IPropertyValueDescriptor<number>;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { IPropertyValueDescriptor } from '../
|
|
1
|
+
import { IPropertyValueDescriptor } from '../property-descriptor';
|
|
2
2
|
export declare const letterSpacing: IPropertyValueDescriptor<number>;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IPropertyTokenValueDescriptor } from '../
|
|
1
|
+
import { IPropertyTokenValueDescriptor } from '../property-descriptor';
|
|
2
2
|
import { CSSValue } from '../syntax/parser';
|
|
3
3
|
export declare const lineHeight: IPropertyTokenValueDescriptor;
|
|
4
4
|
export declare const computeLineHeight: (token: CSSValue, fontSize: number) => number;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IPropertyTokenValueDescriptor } from '../
|
|
1
|
+
import { IPropertyTokenValueDescriptor } from '../property-descriptor';
|
|
2
2
|
export declare const marginTop: IPropertyTokenValueDescriptor;
|
|
3
3
|
export declare const marginRight: IPropertyTokenValueDescriptor;
|
|
4
4
|
export declare const marginBottom: IPropertyTokenValueDescriptor;
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { IPropertyIdentValueDescriptor } from '../property-descriptor';
|
|
2
|
+
export declare const MIX_BLEND_MODE: {
|
|
3
|
+
readonly NORMAL: "normal";
|
|
4
|
+
readonly MULTIPLY: "multiply";
|
|
5
|
+
readonly SCREEN: "screen";
|
|
6
|
+
readonly OVERLAY: "overlay";
|
|
7
|
+
readonly DARKEN: "darken";
|
|
8
|
+
readonly LIGHTEN: "lighten";
|
|
9
|
+
readonly COLOR_DODGE: "color-dodge";
|
|
10
|
+
readonly COLOR_BURN: "color-burn";
|
|
11
|
+
readonly HARD_LIGHT: "hard-light";
|
|
12
|
+
readonly SOFT_LIGHT: "soft-light";
|
|
13
|
+
readonly DIFFERENCE: "difference";
|
|
14
|
+
readonly EXCLUSION: "exclusion";
|
|
15
|
+
readonly HUE: "hue";
|
|
16
|
+
readonly SATURATION: "saturation";
|
|
17
|
+
readonly COLOR: "color";
|
|
18
|
+
readonly LUMINOSITY: "luminosity";
|
|
19
|
+
};
|
|
20
|
+
export type MixBlendMode = (typeof MIX_BLEND_MODE)[keyof typeof MIX_BLEND_MODE];
|
|
21
|
+
export declare const mixBlendMode: IPropertyIdentValueDescriptor<MixBlendMode>;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { IPropertyValueDescriptor } from '../
|
|
1
|
+
import { IPropertyValueDescriptor } from '../property-descriptor';
|
|
2
2
|
export declare const opacity: IPropertyValueDescriptor<number>;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IPropertyTypeValueDescriptor } from '../
|
|
1
|
+
import { IPropertyTypeValueDescriptor } from '../property-descriptor';
|
|
2
2
|
export declare const paddingTop: IPropertyTypeValueDescriptor;
|
|
3
3
|
export declare const paddingRight: IPropertyTypeValueDescriptor;
|
|
4
4
|
export declare const paddingBottom: IPropertyTypeValueDescriptor;
|