fabric 5.3.0 → 6.0.0-beta3
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/.babelrc +11 -0
- package/.babelrcAlt +19 -0
- package/.browserslistrc +5 -0
- package/.eslintignore +3 -0
- package/.eslintrc.js +43 -0
- package/.eslintrc.json +38 -46
- package/.eslintrc_tests +12 -0
- package/.gitattributes +2 -0
- package/.gitpod.yml +17 -1
- package/.prettierignore +19 -0
- package/.prettierrc +4 -0
- package/CHANGELOG.md +532 -189
- package/CONTRIBUTING.md +224 -59
- package/README.md +200 -235
- package/bower.json +1 -3
- package/dist/fabric.d.ts +42 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +27582 -0
- package/dist/index.js.map +1 -0
- package/dist/index.min.js +1 -0
- package/dist/index.mjs +27519 -0
- package/dist/index.mjs.map +1 -0
- package/dist/index.node.cjs +27663 -0
- package/dist/index.node.cjs.map +1 -0
- package/dist/index.node.d.ts +14 -0
- package/dist/index.node.mjs +27606 -0
- package/dist/index.node.mjs.map +1 -0
- package/dist/src/ClassRegistry.d.ts +13 -0
- package/dist/src/Collection.d.ts +136 -0
- package/dist/src/CommonMethods.d.ts +32 -0
- package/dist/src/EventTypeDefs.d.ts +227 -0
- package/dist/src/Intersection.d.ts +112 -0
- package/dist/src/Observable.d.ts +60 -0
- package/dist/src/Pattern.d.ts +113 -0
- package/dist/src/Point.d.ts +232 -0
- package/dist/src/Shadow.d.ts +97 -0
- package/dist/src/brushes/BaseBrush.d.ts +105 -0
- package/dist/src/brushes/CircleBrush.d.ts +49 -0
- package/dist/src/brushes/PatternBrush.d.ts +23 -0
- package/dist/src/brushes/PencilBrush.d.ts +92 -0
- package/dist/src/brushes/SprayBrush.d.ts +79 -0
- package/dist/src/cache.d.ts +47 -0
- package/dist/src/canvas/Canvas.d.ts +548 -0
- package/dist/src/canvas/SelectableCanvas.d.ts +754 -0
- package/dist/src/canvas/StaticCanvas.d.ts +778 -0
- package/dist/src/canvas/TextEditingManager.d.ts +17 -0
- package/dist/src/canvas/canvas_gestures.mixin.d.ts +2 -0
- package/dist/src/color/Color.d.ts +174 -0
- package/dist/src/color/color_map.d.ts +155 -0
- package/dist/src/color/constants.d.ts +22 -0
- package/dist/src/color/util.d.ts +12 -0
- package/dist/src/config.d.ts +115 -0
- package/dist/src/constants.d.ts +14 -0
- package/dist/src/controls/Control.d.ts +228 -0
- package/dist/src/controls/changeWidth.d.ts +13 -0
- package/dist/src/controls/commonControls.d.ts +28 -0
- package/dist/src/controls/controlRendering.d.ts +29 -0
- package/dist/src/controls/drag.d.ts +12 -0
- package/dist/src/controls/index.d.ts +13 -0
- package/dist/src/controls/polyControl.d.ts +5 -0
- package/dist/src/controls/rotate.d.ts +12 -0
- package/dist/src/controls/scale.d.ts +47 -0
- package/dist/src/controls/scaleSkew.d.ts +39 -0
- package/dist/src/controls/skew.d.ts +33 -0
- package/dist/src/controls/util.d.ts +41 -0
- package/dist/src/controls/wrapWithFireEvent.d.ts +8 -0
- package/dist/src/controls/wrapWithFixedAnchor.d.ts +9 -0
- package/dist/src/env/browser.d.ts +3 -0
- package/dist/src/env/index.d.ts +15 -0
- package/dist/src/env/node.d.ts +5 -0
- package/dist/src/env/types.d.ts +15 -0
- package/dist/src/filters/BaseFilter.d.ts +153 -0
- package/dist/src/filters/BlendColor.d.ts +80 -0
- package/dist/src/filters/BlendImage.d.ts +92 -0
- package/dist/src/filters/Blur.d.ts +51 -0
- package/dist/src/filters/Boilerplate.d.ts +48 -0
- package/dist/src/filters/Brightness.d.ts +47 -0
- package/dist/src/filters/Canvas2dFilterBackend.d.ts +27 -0
- package/dist/src/filters/ColorMatrix.d.ts +63 -0
- package/dist/src/filters/ColorMatrixFilters.d.ts +545 -0
- package/dist/src/filters/Composed.d.ts +45 -0
- package/dist/src/filters/Contrast.d.ts +45 -0
- package/dist/src/filters/Convolute.d.ts +82 -0
- package/dist/src/filters/FilterBackend.d.ts +14 -0
- package/dist/src/filters/GLProbes/GLProbe.d.ts +11 -0
- package/dist/src/filters/GLProbes/NodeGLProbe.d.ts +11 -0
- package/dist/src/filters/GLProbes/WebGLProbe.d.ts +20 -0
- package/dist/src/filters/Gamma.d.ts +54 -0
- package/dist/src/filters/Grayscale.d.ts +46 -0
- package/dist/src/filters/HueRotation.d.ts +24 -0
- package/dist/src/filters/Invert.d.ts +55 -0
- package/dist/src/filters/Noise.d.ts +54 -0
- package/dist/src/filters/Pixelate.d.ts +44 -0
- package/dist/src/filters/RemoveColor.d.ts +63 -0
- package/dist/src/filters/Resize.d.ts +136 -0
- package/dist/src/filters/Saturation.d.ts +48 -0
- package/dist/src/filters/Vibrance.d.ts +48 -0
- package/dist/src/filters/WebGLFilterBackend.d.ts +126 -0
- package/dist/src/filters/filters.d.ts +21 -0
- package/dist/src/filters/index.d.ts +5 -0
- package/dist/src/filters/shaders/baseFilter.d.ts +4 -0
- package/dist/src/filters/shaders/blendColor.d.ts +13 -0
- package/dist/src/filters/shaders/blendImage.d.ts +3 -0
- package/dist/src/filters/shaders/blur.d.ts +2 -0
- package/dist/src/filters/shaders/brightness.d.ts +2 -0
- package/dist/src/filters/shaders/colorMatrix.d.ts +2 -0
- package/dist/src/filters/shaders/constrast.d.ts +2 -0
- package/dist/src/filters/shaders/convolute.d.ts +11 -0
- package/dist/src/filters/shaders/gamma.d.ts +2 -0
- package/dist/src/filters/shaders/grayscale.d.ts +3 -0
- package/dist/src/filters/shaders/invert.d.ts +2 -0
- package/dist/src/filters/shaders/noise.d.ts +2 -0
- package/dist/src/filters/shaders/pixelate.d.ts +2 -0
- package/dist/src/filters/shaders/removeColor.d.ts +2 -0
- package/dist/src/filters/shaders/saturation.d.ts +2 -0
- package/dist/src/filters/shaders/vibrance.d.ts +2 -0
- package/dist/src/filters/typedefs.d.ts +49 -0
- package/dist/src/gradient/Gradient.d.ts +149 -0
- package/dist/src/gradient/constants.d.ts +15 -0
- package/dist/src/gradient/parser/index.d.ts +4 -0
- package/dist/src/gradient/parser/misc.d.ts +4 -0
- package/dist/src/gradient/parser/parseColorStops.d.ts +3 -0
- package/dist/src/gradient/parser/parseCoords.d.ts +17 -0
- package/dist/src/gradient/typedefs.d.ts +93 -0
- package/dist/src/mixins/eraser_brush.mixin.d.ts +2 -0
- package/dist/src/parkinglot/canvas_animation.mixin.d.ts +2 -0
- package/dist/src/parkinglot/straighten.d.ts +2 -0
- package/dist/src/parser/applyViewboxTransform.d.ts +5 -0
- package/dist/src/parser/attributes.d.ts +6 -0
- package/dist/src/parser/constants.d.ts +53 -0
- package/dist/src/parser/doesSomeParentMatch.d.ts +2 -0
- package/dist/src/parser/elementById.d.ts +6 -0
- package/dist/src/parser/elementMatchesRule.d.ts +5 -0
- package/dist/src/parser/elements_parser.d.ts +3 -0
- package/dist/src/parser/getCSSRules.d.ts +7 -0
- package/dist/src/parser/getGlobalStylesForElement.d.ts +5 -0
- package/dist/src/parser/getGradientDefs.d.ts +7 -0
- package/dist/src/parser/getMultipleNodes.d.ts +2 -0
- package/dist/src/parser/getSvgRegex.d.ts +2 -0
- package/dist/src/parser/hasAncestorWithNodeName.d.ts +2 -0
- package/dist/src/parser/index.d.ts +10 -0
- package/dist/src/parser/loadSVGFromString.d.ts +12 -0
- package/dist/src/parser/loadSVGFromURL.d.ts +13 -0
- package/dist/src/parser/normalizeAttr.d.ts +2 -0
- package/dist/src/parser/normalizeValue.d.ts +2 -0
- package/dist/src/parser/parseAttributes.d.ts +9 -0
- package/dist/src/parser/parseElements.d.ts +11 -0
- package/dist/src/parser/parseFontDeclaration.d.ts +10 -0
- package/dist/src/parser/parsePointsAttribute.d.ts +12 -0
- package/dist/src/parser/parseSVGDocument.d.ts +15 -0
- package/dist/src/parser/parseStyleAttribute.d.ts +9 -0
- package/dist/src/parser/parseStyleObject.d.ts +2 -0
- package/dist/src/parser/parseStyleString.d.ts +2 -0
- package/dist/src/parser/parseTransformAttribute.d.ts +10 -0
- package/dist/src/parser/parseUseDirectives.d.ts +2 -0
- package/dist/src/parser/percent.d.ts +9 -0
- package/dist/src/parser/recursivelyParseGradientsXlink.d.ts +2 -0
- package/dist/src/parser/rotateMatrix.d.ts +2 -0
- package/dist/src/parser/scaleMatrix.d.ts +2 -0
- package/dist/src/parser/selectorMatches.d.ts +2 -0
- package/dist/src/parser/setStrokeFillOpacity.d.ts +6 -0
- package/dist/src/parser/skewMatrix.d.ts +2 -0
- package/dist/src/parser/translateMatrix.d.ts +2 -0
- package/dist/src/shapes/ActiveSelection.d.ts +82 -0
- package/dist/src/shapes/Circle.d.ts +99 -0
- package/dist/src/shapes/Ellipse.d.ts +84 -0
- package/dist/src/shapes/Group.d.ts +408 -0
- package/dist/src/shapes/IText/DraggableTextDelegate.d.ts +78 -0
- package/dist/src/shapes/IText/IText.d.ts +335 -0
- package/dist/src/shapes/IText/ITextBehavior.d.ts +287 -0
- package/dist/src/shapes/IText/ITextClickBehavior.d.ts +83 -0
- package/dist/src/shapes/IText/ITextKeyBehavior.d.ts +195 -0
- package/dist/src/shapes/IText/constants.d.ts +13 -0
- package/dist/src/shapes/Image.d.ts +311 -0
- package/dist/src/shapes/Line.d.ts +126 -0
- package/dist/src/shapes/Object/AnimatableObject.d.ts +33 -0
- package/dist/src/shapes/Object/FabricObject.d.ts +11 -0
- package/dist/src/shapes/Object/FabricObjectSVGExportMixin.d.ts +74 -0
- package/dist/src/shapes/Object/InteractiveObject.d.ts +296 -0
- package/dist/src/shapes/Object/Object.d.ts +594 -0
- package/dist/src/shapes/Object/ObjectGeometry.d.ts +327 -0
- package/dist/src/shapes/Object/ObjectOrigin.d.ts +109 -0
- package/dist/src/shapes/Object/StackedObject.d.ts +72 -0
- package/dist/src/shapes/Object/defaultValues.d.ts +76 -0
- package/dist/src/shapes/Object/types/BaseProps.d.ts +84 -0
- package/dist/src/shapes/Object/types/BorderProps.d.ts +37 -0
- package/dist/src/shapes/Object/types/ControlProps.d.ts +62 -0
- package/dist/src/shapes/Object/types/FabricObjectProps.d.ts +96 -0
- package/dist/src/shapes/Object/types/FillStrokeProps.d.ts +80 -0
- package/dist/src/shapes/Object/types/LockInteractionProps.d.ts +51 -0
- package/dist/src/shapes/Object/types/ObjectProps.d.ts +42 -0
- package/dist/src/shapes/Object/types/SerializedObjectProps.d.ts +66 -0
- package/dist/src/shapes/Object/types/index.d.ts +6 -0
- package/dist/src/shapes/Path.d.ts +130 -0
- package/dist/src/shapes/Polygon.d.ts +9 -0
- package/dist/src/shapes/Polyline.d.ts +140 -0
- package/dist/src/shapes/Rect.d.ts +76 -0
- package/dist/src/shapes/Text/StyledText.d.ts +119 -0
- package/dist/src/shapes/Text/Text.d.ts +673 -0
- package/dist/src/shapes/Text/TextSVGExportMixin.d.ts +32 -0
- package/dist/src/shapes/Text/constants.d.ts +7 -0
- package/dist/src/shapes/Textbox.d.ts +185 -0
- package/dist/src/shapes/Triangle.d.ts +25 -0
- package/dist/src/typedefs.d.ts +90 -0
- package/dist/src/util/animation/AnimationBase.d.ts +54 -0
- package/dist/src/util/animation/AnimationFrameProvider.d.ts +3 -0
- package/dist/src/util/animation/AnimationRegistry.d.ts +29 -0
- package/dist/src/util/animation/ArrayAnimation.d.ts +10 -0
- package/dist/src/util/animation/ColorAnimation.d.ts +11 -0
- package/dist/src/util/animation/ValueAnimation.d.ts +10 -0
- package/dist/src/util/animation/animate.d.ts +37 -0
- package/dist/src/util/animation/easing.d.ts +130 -0
- package/dist/src/util/animation/types.d.ts +87 -0
- package/dist/src/util/applyMixins.d.ts +8 -0
- package/dist/src/util/dom_event.d.ts +5 -0
- package/dist/src/util/dom_misc.d.ts +39 -0
- package/dist/src/util/dom_request.d.ts +14 -0
- package/dist/src/util/dom_style.d.ts +7 -0
- package/dist/src/util/fireEvent.d.ts +3 -0
- package/dist/src/util/index.d.ts +35 -0
- package/dist/src/util/internals/cloneDeep.d.ts +2 -0
- package/dist/src/util/internals/getRandomInt.d.ts +8 -0
- package/dist/src/util/internals/ifNaN.d.ts +8 -0
- package/dist/src/util/internals/index.d.ts +4 -0
- package/dist/src/util/internals/removeFromArray.d.ts +9 -0
- package/dist/src/util/internals/uid.d.ts +2 -0
- package/dist/src/util/lang_string.d.ts +22 -0
- package/dist/src/util/misc/boundingBoxFromPoints.d.ts +9 -0
- package/dist/src/util/misc/capValue.d.ts +2 -0
- package/dist/src/util/misc/cos.d.ts +10 -0
- package/dist/src/util/misc/dom.d.ts +28 -0
- package/dist/src/util/misc/findScaleTo.d.ts +29 -0
- package/dist/src/util/misc/groupSVGElements.d.ts +9 -0
- package/dist/src/util/misc/isTransparent.d.ts +11 -0
- package/dist/src/util/misc/matrix.d.ts +92 -0
- package/dist/src/util/misc/mergeClipPaths.d.ts +23 -0
- package/dist/src/util/misc/objectEnlive.d.ts +56 -0
- package/dist/src/util/misc/objectTransforms.d.ts +68 -0
- package/dist/src/util/misc/pick.d.ts +9 -0
- package/dist/src/util/misc/planeChange.d.ts +84 -0
- package/dist/src/util/misc/projectStroke/StrokeLineCapProjections.d.ts +51 -0
- package/dist/src/util/misc/projectStroke/StrokeLineJoinProjections.d.ts +81 -0
- package/dist/src/util/misc/projectStroke/StrokeProjectionsBase.d.ts +25 -0
- package/dist/src/util/misc/projectStroke/index.d.ts +11 -0
- package/dist/src/util/misc/projectStroke/types.d.ts +23 -0
- package/dist/src/util/misc/radiansDegreesConversion.d.ts +14 -0
- package/dist/src/util/misc/resolveOrigin.d.ts +9 -0
- package/dist/src/util/misc/rotatePoint.d.ts +12 -0
- package/dist/src/util/misc/sin.d.ts +10 -0
- package/dist/src/util/misc/svgParsing.d.ts +53 -0
- package/dist/src/util/misc/textStyles.d.ts +32 -0
- package/dist/src/util/misc/toFixed.d.ts +8 -0
- package/dist/src/util/misc/vectors.d.ts +57 -0
- package/dist/src/util/path/index.d.ts +96 -0
- package/dist/src/util/path/regex.d.ts +3 -0
- package/dist/src/util/path/typechecks.d.ts +24 -0
- package/dist/src/util/path/typedefs.d.ts +220 -0
- package/dist/src/util/transform_matrix_removal.d.ts +14 -0
- package/dist/src/util/types.d.ts +19 -0
- package/fabric.ts +51 -0
- package/index.node.ts +37 -0
- package/index.ts +1 -0
- package/package.json +100 -40
- package/publish.js +0 -26
- package/rollup.config.mjs +91 -0
- package/rollup.test.config.js +24 -0
- package/scripts/build.mjs +50 -0
- package/scripts/buildLock.mjs +115 -0
- package/scripts/buildReporter.mjs +15 -0
- package/scripts/buildStats.mjs +139 -0
- package/scripts/dirname.mjs +14 -0
- package/scripts/git.mjs +36 -0
- package/scripts/index.mjs +564 -0
- package/scripts/sandbox.mjs +149 -0
- package/src/ClassRegistry.ts +56 -0
- package/src/Collection.ts +346 -0
- package/src/CommonMethods.ts +63 -0
- package/src/EventTypeDefs.ts +296 -0
- package/src/Intersection.ts +302 -0
- package/src/Observable.ts +181 -0
- package/src/Pattern.ts +227 -0
- package/src/Point.ts +388 -0
- package/src/Shadow.ts +214 -0
- package/src/brushes/{base_brush.class.js → BaseBrush.ts} +65 -42
- package/src/brushes/CircleBrush.ts +145 -0
- package/src/brushes/PatternBrush.ts +70 -0
- package/src/brushes/PencilBrush.ts +300 -0
- package/src/brushes/SprayBrush.ts +219 -0
- package/src/cache.ts +90 -0
- package/src/canvas/Canvas.ts +1607 -0
- package/src/canvas/SelectableCanvas.ts +1608 -0
- package/src/canvas/StaticCanvas.ts +1734 -0
- package/src/canvas/TextEditingManager.ts +48 -0
- package/src/canvas/canvas_gestures.mixin.ts +207 -0
- package/src/color/Color.ts +404 -0
- package/src/color/color_map.ts +154 -0
- package/src/color/constants.ts +26 -0
- package/src/color/util.ts +32 -0
- package/src/config.ts +159 -0
- package/src/constants.ts +20 -0
- package/src/controls/Control.ts +380 -0
- package/src/controls/changeWidth.ts +52 -0
- package/src/controls/commonControls.ts +105 -0
- package/src/controls/controlRendering.ts +138 -0
- package/src/controls/drag.ts +31 -0
- package/src/controls/index.ts +22 -0
- package/src/controls/polyControl.ts +135 -0
- package/src/controls/rotate.ts +87 -0
- package/src/controls/scale.ts +277 -0
- package/src/controls/scaleSkew.ts +92 -0
- package/src/controls/skew.ts +242 -0
- package/src/controls/util.ts +154 -0
- package/src/controls/wrapWithFireEvent.ts +25 -0
- package/src/controls/wrapWithFixedAnchor.ts +20 -0
- package/src/env/browser.ts +32 -0
- package/src/env/index.ts +24 -0
- package/src/env/node.ts +56 -0
- package/src/env/types.ts +15 -0
- package/src/filters/{base_filter.class.js → BaseFilter.ts} +192 -151
- package/src/filters/BlendColor.ts +217 -0
- package/src/filters/BlendImage.ts +228 -0
- package/src/filters/Blur.ts +179 -0
- package/src/filters/Boilerplate.ts +94 -0
- package/src/filters/Brightness.ts +83 -0
- package/src/filters/Canvas2dFilterBackend.ts +65 -0
- package/src/filters/ColorMatrix.ts +145 -0
- package/src/filters/ColorMatrixFilters.ts +77 -0
- package/src/filters/Composed.ts +76 -0
- package/src/filters/Contrast.ts +82 -0
- package/src/filters/Convolute.ts +184 -0
- package/src/filters/FilterBackend.ts +34 -0
- package/src/filters/GLProbes/GLProbe.ts +11 -0
- package/src/filters/GLProbes/NodeGLProbe.ts +15 -0
- package/src/filters/GLProbes/WebGLProbe.ts +46 -0
- package/src/filters/Gamma.ts +110 -0
- package/src/filters/Grayscale.ts +102 -0
- package/src/filters/HueRotation.ts +62 -0
- package/src/filters/Invert.ts +99 -0
- package/src/filters/Noise.ts +94 -0
- package/src/filters/Pixelate.ts +96 -0
- package/src/filters/RemoveColor.ts +135 -0
- package/src/filters/Resize.ts +538 -0
- package/src/filters/Saturation.ts +87 -0
- package/src/filters/Vibrance.ts +88 -0
- package/src/filters/WebGLFilterBackend.ts +430 -0
- package/src/filters/filters.ts +28 -0
- package/src/filters/index.ts +5 -0
- package/src/filters/shaders/baseFilter.ts +19 -0
- package/src/filters/shaders/blendColor.ts +33 -0
- package/src/filters/shaders/blendImage.ts +32 -0
- package/src/filters/shaders/blur.ts +24 -0
- package/src/filters/shaders/brightness.ts +11 -0
- package/src/filters/shaders/colorMatrix.ts +12 -0
- package/src/filters/shaders/constrast.ts +11 -0
- package/src/filters/shaders/convolute.ts +154 -0
- package/src/filters/shaders/gamma.ts +15 -0
- package/src/filters/shaders/grayscale.ts +36 -0
- package/src/filters/shaders/invert.ts +19 -0
- package/src/filters/shaders/noise.ts +16 -0
- package/src/filters/shaders/pixelate.ts +19 -0
- package/src/filters/shaders/removeColor.ts +13 -0
- package/src/filters/shaders/saturation.ts +15 -0
- package/src/filters/shaders/vibrance.ts +16 -0
- package/src/filters/typedefs.ts +65 -0
- package/src/gradient/Gradient.ts +406 -0
- package/src/gradient/constants.ts +12 -0
- package/src/gradient/parser/index.ts +3 -0
- package/src/gradient/parser/misc.ts +13 -0
- package/src/gradient/parser/parseColorStops.ts +56 -0
- package/src/gradient/parser/parseCoords.ts +73 -0
- package/src/gradient/typedefs.ts +104 -0
- package/src/mixins/{eraser_brush.mixin.js → eraser_brush.mixin.ts} +350 -239
- package/src/parkinglot/canvas_animation.mixin.ts +121 -0
- package/src/parkinglot/straighten.ts +58 -0
- package/src/parser/applyViewboxTransform.ts +157 -0
- package/src/parser/attributes.ts +25 -0
- package/src/parser/constants.ts +115 -0
- package/src/parser/doesSomeParentMatch.ts +19 -0
- package/src/parser/elementById.ts +21 -0
- package/src/parser/elementMatchesRule.ts +16 -0
- package/src/parser/elements_parser.ts +191 -0
- package/src/parser/getCSSRules.ts +62 -0
- package/src/parser/getGlobalStylesForElement.ts +19 -0
- package/src/parser/getGradientDefs.ts +31 -0
- package/src/parser/getMultipleNodes.ts +15 -0
- package/src/parser/getSvgRegex.ts +5 -0
- package/src/parser/hasAncestorWithNodeName.ts +14 -0
- package/src/parser/index.ts +9 -0
- package/src/parser/loadSVGFromString.ts +26 -0
- package/src/parser/loadSVGFromURL.ts +40 -0
- package/src/parser/normalizeAttr.ts +10 -0
- package/src/parser/normalizeValue.ts +63 -0
- package/src/parser/parseAttributes.ts +90 -0
- package/src/parser/parseElements.ts +28 -0
- package/src/parser/parseFontDeclaration.ts +44 -0
- package/src/parser/parsePointsAttribute.ts +34 -0
- package/src/parser/parseSVGDocument.ts +93 -0
- package/src/parser/parseStyleAttribute.ts +27 -0
- package/src/parser/parseStyleObject.ts +15 -0
- package/src/parser/parseStyleString.ts +16 -0
- package/src/parser/parseTransformAttribute.ts +155 -0
- package/src/parser/parseUseDirectives.ts +78 -0
- package/src/parser/percent.ts +27 -0
- package/src/parser/recursivelyParseGradientsXlink.ts +42 -0
- package/src/parser/rotateMatrix.ts +21 -0
- package/src/parser/scaleMatrix.ts +9 -0
- package/src/parser/selectorMatches.ts +25 -0
- package/src/parser/setStrokeFillOpacity.ts +40 -0
- package/src/parser/skewMatrix.ts +6 -0
- package/src/parser/translateMatrix.ts +8 -0
- package/src/shapes/ActiveSelection.ts +189 -0
- package/src/shapes/Circle.ts +242 -0
- package/src/shapes/Ellipse.ts +179 -0
- package/src/shapes/Group.ts +1100 -0
- package/src/shapes/IText/DraggableTextDelegate.ts +382 -0
- package/src/shapes/IText/IText.ts +693 -0
- package/src/shapes/IText/ITextBehavior.ts +1064 -0
- package/src/shapes/IText/ITextClickBehavior.ts +325 -0
- package/src/shapes/IText/ITextKeyBehavior.ts +685 -0
- package/src/shapes/IText/constants.ts +47 -0
- package/src/shapes/Image.ts +841 -0
- package/src/shapes/Line.ts +346 -0
- package/src/shapes/Object/AnimatableObject.ts +106 -0
- package/src/shapes/Object/FabricObject.ts +29 -0
- package/src/shapes/Object/FabricObjectSVGExportMixin.ts +277 -0
- package/src/shapes/Object/InteractiveObject.ts +672 -0
- package/src/shapes/Object/Object.ts +1561 -0
- package/src/shapes/Object/ObjectGeometry.ts +813 -0
- package/src/shapes/Object/ObjectOrigin.ts +276 -0
- package/src/shapes/Object/StackedObject.ts +206 -0
- package/src/shapes/Object/defaultValues.ts +108 -0
- package/src/shapes/Object/types/BaseProps.ts +96 -0
- package/src/shapes/Object/types/BorderProps.ts +40 -0
- package/src/shapes/Object/types/ControlProps.ts +69 -0
- package/src/shapes/Object/types/FabricObjectProps.ts +111 -0
- package/src/shapes/Object/types/FillStrokeProps.ts +90 -0
- package/src/shapes/Object/types/LockInteractionProps.ts +57 -0
- package/src/shapes/Object/types/ObjectProps.ts +46 -0
- package/src/shapes/Object/types/SerializedObjectProps.ts +73 -0
- package/src/shapes/Object/types/index.ts +8 -0
- package/src/shapes/Path.ts +416 -0
- package/src/shapes/Polygon.ts +20 -0
- package/src/shapes/Polyline.ts +359 -0
- package/src/shapes/Rect.ts +233 -0
- package/src/shapes/Text/StyledText.ts +329 -0
- package/src/shapes/Text/Text.ts +1884 -0
- package/src/shapes/Text/TextSVGExportMixin.ts +288 -0
- package/src/shapes/Text/constants.ts +91 -0
- package/src/shapes/Textbox.ts +477 -0
- package/src/shapes/Triangle.ts +60 -0
- package/src/typedefs.ts +115 -0
- package/src/util/animation/AnimationBase.ts +166 -0
- package/src/util/animation/AnimationFrameProvider.ts +9 -0
- package/src/util/animation/AnimationRegistry.ts +58 -0
- package/src/util/animation/ArrayAnimation.ts +27 -0
- package/src/util/animation/ColorAnimation.ts +74 -0
- package/src/util/animation/ValueAnimation.ts +29 -0
- package/src/util/animation/animate.ts +74 -0
- package/src/util/animation/easing.ts +327 -0
- package/src/util/animation/types.ts +136 -0
- package/src/util/applyMixins.ts +22 -0
- package/src/util/dom_event.ts +28 -0
- package/src/util/dom_misc.ts +121 -0
- package/src/util/dom_request.ts +64 -0
- package/src/util/dom_style.ts +20 -0
- package/src/util/fireEvent.ts +15 -0
- package/src/util/index.ts +102 -0
- package/src/util/internals/cloneDeep.ts +2 -0
- package/src/util/internals/getRandomInt.ts +8 -0
- package/src/util/internals/ifNaN.ts +9 -0
- package/src/util/internals/index.ts +3 -0
- package/src/util/internals/removeFromArray.ts +14 -0
- package/src/util/internals/uid.ts +3 -0
- package/src/util/lang_string.ts +79 -0
- package/src/util/misc/boundingBoxFromPoints.ts +37 -0
- package/src/util/misc/capValue.ts +2 -0
- package/src/util/misc/cos.ts +24 -0
- package/src/util/misc/dom.ts +50 -0
- package/src/util/misc/findScaleTo.ts +44 -0
- package/src/util/misc/groupSVGElements.ts +15 -0
- package/src/util/misc/isTransparent.ts +28 -0
- package/src/util/misc/matrix.ts +207 -0
- package/src/util/misc/mergeClipPaths.ts +40 -0
- package/src/util/misc/objectEnlive.ts +189 -0
- package/src/util/misc/objectTransforms.ts +129 -0
- package/src/util/misc/pick.ts +29 -0
- package/src/util/misc/planeChange.ts +136 -0
- package/src/util/misc/projectStroke/StrokeLineCapProjections.ts +112 -0
- package/src/util/misc/projectStroke/StrokeLineJoinProjections.ts +226 -0
- package/src/util/misc/projectStroke/StrokeProjectionsBase.ts +75 -0
- package/src/util/misc/projectStroke/index.ts +53 -0
- package/src/util/misc/projectStroke/types.ts +24 -0
- package/src/util/misc/radiansDegreesConversion.ts +18 -0
- package/src/util/misc/resolveOrigin.ts +22 -0
- package/src/util/misc/rotatePoint.ts +15 -0
- package/src/util/misc/sin.ts +26 -0
- package/src/util/misc/svgParsing.ts +181 -0
- package/src/util/misc/textStyles.ts +134 -0
- package/src/util/misc/toFixed.ts +8 -0
- package/src/util/misc/vectors.ts +82 -0
- package/src/util/path/index.ts +1038 -0
- package/src/util/path/regex.ts +41 -0
- package/src/util/path/typechecks.ts +145 -0
- package/src/util/path/typedefs.ts +305 -0
- package/src/util/transform_matrix_removal.ts +60 -0
- package/src/util/types.ts +78 -0
- package/tsconfig.json +106 -0
- package/HEADER.js +0 -203
- package/build.js +0 -287
- package/dist/fabric.js +0 -31187
- package/dist/fabric.min.js +0 -1
- package/old-travis-reference.yml +0 -97
- package/src/brushes/circle_brush.class.js +0 -144
- package/src/brushes/pattern_brush.class.js +0 -61
- package/src/brushes/pencil_brush.class.js +0 -310
- package/src/brushes/spray_brush.class.js +0 -219
- package/src/canvas.class.js +0 -1312
- package/src/color.class.js +0 -636
- package/src/control.class.js +0 -339
- package/src/controls.actions.js +0 -740
- package/src/controls.render.js +0 -99
- package/src/elements_parser.js +0 -152
- package/src/filters/2d_backend.class.js +0 -65
- package/src/filters/blendcolor_filter.class.js +0 -251
- package/src/filters/blendimage_filter.class.js +0 -247
- package/src/filters/blur_filter.class.js +0 -217
- package/src/filters/brightness_filter.class.js +0 -113
- package/src/filters/colormatrix_filter.class.js +0 -159
- package/src/filters/composed_filter.class.js +0 -72
- package/src/filters/contrast_filter.class.js +0 -113
- package/src/filters/convolute_filter.class.js +0 -352
- package/src/filters/filter_boilerplate.js +0 -111
- package/src/filters/filter_generator.js +0 -85
- package/src/filters/gamma_filter.class.js +0 -136
- package/src/filters/grayscale_filter.class.js +0 -154
- package/src/filters/hue_rotation.class.js +0 -107
- package/src/filters/invert_filter.class.js +0 -111
- package/src/filters/noise_filter.class.js +0 -134
- package/src/filters/pixelate_filter.class.js +0 -137
- package/src/filters/removecolor_filter.class.js +0 -173
- package/src/filters/resize_filter.class.js +0 -490
- package/src/filters/saturate_filter.class.js +0 -119
- package/src/filters/vibrance_filter.class.js +0 -122
- package/src/filters/webgl_backend.class.js +0 -396
- package/src/globalFabric.js +0 -4
- package/src/gradient.class.js +0 -490
- package/src/intersection.class.js +0 -172
- package/src/log.js +0 -11
- package/src/mixins/animation.mixin.js +0 -231
- package/src/mixins/canvas_dataurl_exporter.mixin.js +0 -97
- package/src/mixins/canvas_events.mixin.js +0 -974
- package/src/mixins/canvas_gestures.mixin.js +0 -149
- package/src/mixins/canvas_grouping.mixin.js +0 -177
- package/src/mixins/canvas_serialization.mixin.js +0 -228
- package/src/mixins/collection.mixin.js +0 -170
- package/src/mixins/default_controls.js +0 -114
- package/src/mixins/itext.svg_export.js +0 -241
- package/src/mixins/itext_behavior.mixin.js +0 -940
- package/src/mixins/itext_click_behavior.mixin.js +0 -278
- package/src/mixins/itext_key_behavior.mixin.js +0 -694
- package/src/mixins/object.svg_export.js +0 -258
- package/src/mixins/object_geometry.mixin.js +0 -683
- package/src/mixins/object_interactivity.mixin.js +0 -314
- package/src/mixins/object_origin.mixin.js +0 -255
- package/src/mixins/object_stacking.mixin.js +0 -80
- package/src/mixins/object_straightening.mixin.js +0 -80
- package/src/mixins/observable.mixin.js +0 -141
- package/src/mixins/shared_methods.mixin.js +0 -94
- package/src/mixins/stateful.mixin.js +0 -107
- package/src/mixins/text_style.mixin.js +0 -324
- package/src/parser.js +0 -1090
- package/src/pattern.class.js +0 -189
- package/src/point.class.js +0 -337
- package/src/shadow.class.js +0 -195
- package/src/shapes/active_selection.class.js +0 -155
- package/src/shapes/circle.class.js +0 -210
- package/src/shapes/ellipse.class.js +0 -181
- package/src/shapes/group.class.js +0 -593
- package/src/shapes/image.class.js +0 -764
- package/src/shapes/itext.class.js +0 -526
- package/src/shapes/line.class.js +0 -324
- package/src/shapes/object.class.js +0 -2008
- package/src/shapes/path.class.js +0 -384
- package/src/shapes/polygon.class.js +0 -81
- package/src/shapes/polyline.class.js +0 -268
- package/src/shapes/rect.class.js +0 -187
- package/src/shapes/text.class.js +0 -1696
- package/src/shapes/textbox.class.js +0 -461
- package/src/shapes/triangle.class.js +0 -93
- package/src/static_canvas.class.js +0 -1881
- package/src/util/anim_ease.js +0 -398
- package/src/util/animate.js +0 -254
- package/src/util/animate_color.js +0 -74
- package/src/util/dom_event.js +0 -50
- package/src/util/dom_misc.js +0 -300
- package/src/util/dom_request.js +0 -54
- package/src/util/dom_style.js +0 -70
- package/src/util/lang_array.js +0 -94
- package/src/util/lang_class.js +0 -115
- package/src/util/lang_object.js +0 -75
- package/src/util/lang_string.js +0 -110
- package/src/util/misc.js +0 -1330
- package/src/util/named_accessors.mixin.js +0 -428
- package/src/util/path.js +0 -829
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* This Map connects the objects type value with their
|
|
3
|
+
* class implementation. It used from any object to understand which are
|
|
4
|
+
* the classes to enlive when requesting a object.type = 'path' for example.
|
|
5
|
+
* Objects uses it for clipPath, Canvas uses it for everything.
|
|
6
|
+
* This is necessary for generic code to run and enlive instances from serialized representation.
|
|
7
|
+
* You can customize which classes get enlived from SVG parsing using this classRegistry.
|
|
8
|
+
* The Registry start empty and gets filled in depending which files you import.
|
|
9
|
+
* If you want to be able to parse arbitrary SVGs or JSON representation of canvases, coming from
|
|
10
|
+
* different sources you will need to import all fabric because you may need all classes.
|
|
11
|
+
*/
|
|
12
|
+
|
|
13
|
+
export const JSON = 'json';
|
|
14
|
+
export const SVG = 'svg';
|
|
15
|
+
|
|
16
|
+
export class ClassRegistry {
|
|
17
|
+
declare [JSON]: Map<string, any>;
|
|
18
|
+
declare [SVG]: Map<string, any>;
|
|
19
|
+
|
|
20
|
+
constructor() {
|
|
21
|
+
this[JSON] = new Map();
|
|
22
|
+
this[SVG] = new Map();
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
getClass(classType: string): any {
|
|
26
|
+
const constructor = this[JSON].get(classType);
|
|
27
|
+
if (!constructor) {
|
|
28
|
+
throw new Error(`No class registered for ${classType}`);
|
|
29
|
+
}
|
|
30
|
+
return constructor;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
setClass(classConstructor: any, classType?: string) {
|
|
34
|
+
if (classType) {
|
|
35
|
+
this[JSON].set(classType, classConstructor);
|
|
36
|
+
} else {
|
|
37
|
+
this[JSON].set(classConstructor.name, classConstructor);
|
|
38
|
+
// legacy
|
|
39
|
+
// @TODO: needs to be removed in fabric 7 or 8
|
|
40
|
+
this[JSON].set(classConstructor.name.toLowerCase(), classConstructor);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
getSVGClass(SVGTagName: string): any {
|
|
45
|
+
return this[SVG].get(SVGTagName);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
setSVGClass(classConstructor: any, SVGTagName?: string) {
|
|
49
|
+
this[SVG].set(
|
|
50
|
+
SVGTagName ?? classConstructor.name.toLowerCase(),
|
|
51
|
+
classConstructor
|
|
52
|
+
);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
export const classRegistry = new ClassRegistry();
|
|
@@ -0,0 +1,346 @@
|
|
|
1
|
+
import type { Constructor, TBBox } from './typedefs';
|
|
2
|
+
import type { BaseFabricObject } from './EventTypeDefs';
|
|
3
|
+
import { removeFromArray } from './util/internals';
|
|
4
|
+
import { Point } from './Point';
|
|
5
|
+
import { InteractiveFabricObject } from './shapes/Object/InteractiveObject';
|
|
6
|
+
|
|
7
|
+
export function createCollectionMixin<TBase extends Constructor>(Base: TBase) {
|
|
8
|
+
class Collection extends Base {
|
|
9
|
+
/**
|
|
10
|
+
* @type {BaseFabricObject[]}
|
|
11
|
+
* @TODO needs to end up in the constructor too
|
|
12
|
+
*/
|
|
13
|
+
_objects: BaseFabricObject[] = [];
|
|
14
|
+
|
|
15
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
16
|
+
_onObjectAdded(object: BaseFabricObject) {
|
|
17
|
+
// subclasses should override this method
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
21
|
+
_onObjectRemoved(object: BaseFabricObject) {
|
|
22
|
+
// subclasses should override this method
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
26
|
+
_onStackOrderChanged(object: BaseFabricObject) {
|
|
27
|
+
// subclasses should override this method
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* Adds objects to collection
|
|
32
|
+
* Objects should be instances of (or inherit from) BaseFabricObject
|
|
33
|
+
* @param {...BaseFabricObject[]} objects to add
|
|
34
|
+
* @returns {number} new array length
|
|
35
|
+
*/
|
|
36
|
+
add(...objects: BaseFabricObject[]): number {
|
|
37
|
+
const size = this._objects.push(...objects);
|
|
38
|
+
objects.forEach((object) => this._onObjectAdded(object));
|
|
39
|
+
return size;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* Inserts an object into collection at specified index
|
|
44
|
+
* @param {number} index Index to insert object at
|
|
45
|
+
* @param {...BaseFabricObject[]} objects Object(s) to insert
|
|
46
|
+
* @returns {number} new array length
|
|
47
|
+
*/
|
|
48
|
+
insertAt(index: number, ...objects: BaseFabricObject[]) {
|
|
49
|
+
this._objects.splice(index, 0, ...objects);
|
|
50
|
+
objects.forEach((object) => this._onObjectAdded(object));
|
|
51
|
+
return this._objects.length;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* Removes objects from a collection, then renders canvas (if `renderOnAddRemove` is not `false`)
|
|
56
|
+
* @private
|
|
57
|
+
* @param {...BaseFabricObject[]} objects objects to remove
|
|
58
|
+
* @returns {BaseFabricObject[]} removed objects
|
|
59
|
+
*/
|
|
60
|
+
remove(...objects: BaseFabricObject[]) {
|
|
61
|
+
const array = this._objects,
|
|
62
|
+
removed: BaseFabricObject[] = [];
|
|
63
|
+
objects.forEach((object) => {
|
|
64
|
+
const index = array.indexOf(object);
|
|
65
|
+
// only call onObjectRemoved if an object was actually removed
|
|
66
|
+
if (index !== -1) {
|
|
67
|
+
array.splice(index, 1);
|
|
68
|
+
removed.push(object);
|
|
69
|
+
this._onObjectRemoved(object);
|
|
70
|
+
}
|
|
71
|
+
});
|
|
72
|
+
return removed;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
/**
|
|
76
|
+
* Executes given function for each object in this group
|
|
77
|
+
* A simple shortcut for getObjects().forEach, before es6 was more complicated,
|
|
78
|
+
* now is just a shortcut.
|
|
79
|
+
* @param {Function} callback
|
|
80
|
+
* Callback invoked with current object as first argument,
|
|
81
|
+
* index - as second and an array of all objects - as third.
|
|
82
|
+
*/
|
|
83
|
+
forEachObject(
|
|
84
|
+
callback: (
|
|
85
|
+
object: BaseFabricObject,
|
|
86
|
+
index: number,
|
|
87
|
+
array: BaseFabricObject[]
|
|
88
|
+
) => any
|
|
89
|
+
) {
|
|
90
|
+
this.getObjects().forEach((object, index, objects) =>
|
|
91
|
+
callback(object, index, objects)
|
|
92
|
+
);
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
/**
|
|
96
|
+
* Returns an array of children objects of this instance
|
|
97
|
+
* @param {...String} [types] When specified, only objects of these types are returned
|
|
98
|
+
* @return {Array}
|
|
99
|
+
*/
|
|
100
|
+
getObjects(...types: string[]) {
|
|
101
|
+
if (types.length === 0) {
|
|
102
|
+
return [...this._objects];
|
|
103
|
+
}
|
|
104
|
+
return this._objects.filter((o) => o.isType(...types));
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
/**
|
|
108
|
+
* Returns object at specified index
|
|
109
|
+
* @param {Number} index
|
|
110
|
+
* @return {Object} object at index
|
|
111
|
+
*/
|
|
112
|
+
item(index: number) {
|
|
113
|
+
return this._objects[index];
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
/**
|
|
117
|
+
* Returns true if collection contains no objects
|
|
118
|
+
* @return {Boolean} true if collection is empty
|
|
119
|
+
*/
|
|
120
|
+
isEmpty() {
|
|
121
|
+
return this._objects.length === 0;
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
/**
|
|
125
|
+
* Returns a size of a collection (i.e: length of an array containing its objects)
|
|
126
|
+
* @return {Number} Collection size
|
|
127
|
+
*/
|
|
128
|
+
size() {
|
|
129
|
+
return this._objects.length;
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
/**
|
|
133
|
+
* Returns true if collection contains an object.\
|
|
134
|
+
* **Prefer using {@link `BaseFabricObject#isDescendantOf`} for performance reasons**
|
|
135
|
+
* instead of `a.contains(b)` use `b.isDescendantOf(a)`
|
|
136
|
+
* @param {Object} object Object to check against
|
|
137
|
+
* @param {Boolean} [deep=false] `true` to check all descendants, `false` to check only `_objects`
|
|
138
|
+
* @return {Boolean} `true` if collection contains an object
|
|
139
|
+
*/
|
|
140
|
+
contains(object: BaseFabricObject, deep?: boolean): boolean {
|
|
141
|
+
if (this._objects.includes(object)) {
|
|
142
|
+
return true;
|
|
143
|
+
} else if (deep) {
|
|
144
|
+
return this._objects.some(
|
|
145
|
+
(obj) =>
|
|
146
|
+
obj instanceof Collection &&
|
|
147
|
+
(obj as unknown as Collection).contains(object, true)
|
|
148
|
+
);
|
|
149
|
+
}
|
|
150
|
+
return false;
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
/**
|
|
154
|
+
* Returns number representation of a collection complexity
|
|
155
|
+
* @return {Number} complexity
|
|
156
|
+
*/
|
|
157
|
+
complexity() {
|
|
158
|
+
return this._objects.reduce((memo, current) => {
|
|
159
|
+
memo += current.complexity ? current.complexity() : 0;
|
|
160
|
+
return memo;
|
|
161
|
+
}, 0);
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
/**
|
|
165
|
+
* Moves an object or the objects of a multiple selection
|
|
166
|
+
* to the bottom of the stack of drawn objects
|
|
167
|
+
* @param {fabric.Object} object Object to send to back
|
|
168
|
+
* @returns {boolean} true if change occurred
|
|
169
|
+
*/
|
|
170
|
+
sendObjectToBack(object: BaseFabricObject) {
|
|
171
|
+
if (!object || object === this._objects[0]) {
|
|
172
|
+
return false;
|
|
173
|
+
}
|
|
174
|
+
removeFromArray(this._objects, object);
|
|
175
|
+
this._objects.unshift(object);
|
|
176
|
+
this._onStackOrderChanged(object);
|
|
177
|
+
return true;
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
/**
|
|
181
|
+
* Moves an object or the objects of a multiple selection
|
|
182
|
+
* to the top of the stack of drawn objects
|
|
183
|
+
* @param {fabric.Object} object Object to send
|
|
184
|
+
* @returns {boolean} true if change occurred
|
|
185
|
+
*/
|
|
186
|
+
bringObjectToFront(object: BaseFabricObject) {
|
|
187
|
+
if (!object || object === this._objects[this._objects.length - 1]) {
|
|
188
|
+
return false;
|
|
189
|
+
}
|
|
190
|
+
removeFromArray(this._objects, object);
|
|
191
|
+
this._objects.push(object);
|
|
192
|
+
this._onStackOrderChanged(object);
|
|
193
|
+
return true;
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
/**
|
|
197
|
+
* Moves an object or a selection down in stack of drawn objects
|
|
198
|
+
* An optional parameter, `intersecting` allows to move the object in behind
|
|
199
|
+
* the first intersecting object. Where intersection is calculated with
|
|
200
|
+
* bounding box. If no intersection is found, there will not be change in the
|
|
201
|
+
* stack.
|
|
202
|
+
* @param {fabric.Object} object Object to send
|
|
203
|
+
* @param {boolean} [intersecting] If `true`, send object behind next lower intersecting object
|
|
204
|
+
* @returns {boolean} true if change occurred
|
|
205
|
+
*/
|
|
206
|
+
sendObjectBackwards(object: BaseFabricObject, intersecting?: boolean) {
|
|
207
|
+
if (!object) {
|
|
208
|
+
return false;
|
|
209
|
+
}
|
|
210
|
+
const idx = this._objects.indexOf(object);
|
|
211
|
+
if (idx !== 0) {
|
|
212
|
+
// if object is not on the bottom of stack
|
|
213
|
+
const newIdx = this.findNewLowerIndex(object, idx, intersecting);
|
|
214
|
+
removeFromArray(this._objects, object);
|
|
215
|
+
this._objects.splice(newIdx, 0, object);
|
|
216
|
+
this._onStackOrderChanged(object);
|
|
217
|
+
return true;
|
|
218
|
+
}
|
|
219
|
+
return false;
|
|
220
|
+
}
|
|
221
|
+
|
|
222
|
+
/**
|
|
223
|
+
* Moves an object or a selection up in stack of drawn objects
|
|
224
|
+
* An optional parameter, intersecting allows to move the object in front
|
|
225
|
+
* of the first intersecting object. Where intersection is calculated with
|
|
226
|
+
* bounding box. If no intersection is found, there will not be change in the
|
|
227
|
+
* stack.
|
|
228
|
+
* @param {fabric.Object} object Object to send
|
|
229
|
+
* @param {boolean} [intersecting] If `true`, send object in front of next upper intersecting object
|
|
230
|
+
* @returns {boolean} true if change occurred
|
|
231
|
+
*/
|
|
232
|
+
bringObjectForward(object: BaseFabricObject, intersecting?: boolean) {
|
|
233
|
+
if (!object) {
|
|
234
|
+
return false;
|
|
235
|
+
}
|
|
236
|
+
const idx = this._objects.indexOf(object);
|
|
237
|
+
if (idx !== this._objects.length - 1) {
|
|
238
|
+
// if object is not on top of stack (last item in an array)
|
|
239
|
+
const newIdx = this.findNewUpperIndex(object, idx, intersecting);
|
|
240
|
+
removeFromArray(this._objects, object);
|
|
241
|
+
this._objects.splice(newIdx, 0, object);
|
|
242
|
+
this._onStackOrderChanged(object);
|
|
243
|
+
return true;
|
|
244
|
+
}
|
|
245
|
+
return false;
|
|
246
|
+
}
|
|
247
|
+
|
|
248
|
+
/**
|
|
249
|
+
* Moves an object to specified level in stack of drawn objects
|
|
250
|
+
* @param {fabric.Object} object Object to send
|
|
251
|
+
* @param {number} index Position to move to
|
|
252
|
+
* @returns {boolean} true if change occurred
|
|
253
|
+
*/
|
|
254
|
+
moveObjectTo(object: BaseFabricObject, index: number) {
|
|
255
|
+
if (object === this._objects[index]) {
|
|
256
|
+
return false;
|
|
257
|
+
}
|
|
258
|
+
removeFromArray(this._objects, object);
|
|
259
|
+
this._objects.splice(index, 0, object);
|
|
260
|
+
this._onStackOrderChanged(object);
|
|
261
|
+
return true;
|
|
262
|
+
}
|
|
263
|
+
|
|
264
|
+
findNewLowerIndex(
|
|
265
|
+
object: BaseFabricObject,
|
|
266
|
+
idx: number,
|
|
267
|
+
intersecting?: boolean
|
|
268
|
+
) {
|
|
269
|
+
let newIdx;
|
|
270
|
+
|
|
271
|
+
if (intersecting) {
|
|
272
|
+
newIdx = idx;
|
|
273
|
+
// traverse down the stack looking for the nearest intersecting object
|
|
274
|
+
for (let i = idx - 1; i >= 0; --i) {
|
|
275
|
+
if (object.isOverlapping(this._objects[i])) {
|
|
276
|
+
newIdx = i;
|
|
277
|
+
break;
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
} else {
|
|
281
|
+
newIdx = idx - 1;
|
|
282
|
+
}
|
|
283
|
+
|
|
284
|
+
return newIdx;
|
|
285
|
+
}
|
|
286
|
+
|
|
287
|
+
findNewUpperIndex(
|
|
288
|
+
object: BaseFabricObject,
|
|
289
|
+
idx: number,
|
|
290
|
+
intersecting?: boolean
|
|
291
|
+
) {
|
|
292
|
+
let newIdx;
|
|
293
|
+
|
|
294
|
+
if (intersecting) {
|
|
295
|
+
newIdx = idx;
|
|
296
|
+
// traverse up the stack looking for the nearest intersecting object
|
|
297
|
+
for (let i = idx + 1; i < this._objects.length; ++i) {
|
|
298
|
+
if (object.isOverlapping(this._objects[i])) {
|
|
299
|
+
newIdx = i;
|
|
300
|
+
break;
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
} else {
|
|
304
|
+
newIdx = idx + 1;
|
|
305
|
+
}
|
|
306
|
+
|
|
307
|
+
return newIdx;
|
|
308
|
+
}
|
|
309
|
+
|
|
310
|
+
/**
|
|
311
|
+
* Given a bounding box, return all the objects of the collection that are contained in the bounding box.
|
|
312
|
+
* If `includeIntersecting` is true, return also the objects that intersect the bounding box as well.
|
|
313
|
+
* This is meant to work with selection. Is not a generic method.
|
|
314
|
+
* @returns array of objects contained in the bounding box, ordered from top to bottom stacking wise
|
|
315
|
+
*/
|
|
316
|
+
collectObjects(
|
|
317
|
+
{ left, top, width, height }: TBBox,
|
|
318
|
+
{ includeIntersecting = true }: { includeIntersecting?: boolean } = {}
|
|
319
|
+
) {
|
|
320
|
+
const objects: InteractiveFabricObject[] = [],
|
|
321
|
+
tl = new Point(left, top),
|
|
322
|
+
br = tl.add(new Point(width, height));
|
|
323
|
+
|
|
324
|
+
// we iterate reverse order to collect top first in case of click.
|
|
325
|
+
for (let i = this._objects.length - 1; i >= 0; i--) {
|
|
326
|
+
const object = this._objects[i] as unknown as InteractiveFabricObject;
|
|
327
|
+
if (
|
|
328
|
+
object.selectable &&
|
|
329
|
+
object.visible &&
|
|
330
|
+
((includeIntersecting && object.intersectsWithRect(tl, br, true)) ||
|
|
331
|
+
object.isContainedWithinRect(tl, br, true) ||
|
|
332
|
+
(includeIntersecting &&
|
|
333
|
+
object.containsPoint(tl, undefined, true)) ||
|
|
334
|
+
(includeIntersecting && object.containsPoint(br, undefined, true)))
|
|
335
|
+
) {
|
|
336
|
+
objects.push(object);
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
|
|
340
|
+
return objects;
|
|
341
|
+
}
|
|
342
|
+
}
|
|
343
|
+
|
|
344
|
+
// https://github.com/microsoft/TypeScript/issues/32080
|
|
345
|
+
return Collection as typeof Collection & TBase;
|
|
346
|
+
}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
//@ts-nocheck
|
|
2
|
+
import { Observable } from './Observable';
|
|
3
|
+
|
|
4
|
+
export class CommonMethods<EventSpec> extends Observable<EventSpec> {
|
|
5
|
+
/**
|
|
6
|
+
* Sets object's properties from options, for initialization only
|
|
7
|
+
* @protected
|
|
8
|
+
* @param {Object} [options] Options object
|
|
9
|
+
*/
|
|
10
|
+
protected _setOptions(options: any = {}) {
|
|
11
|
+
for (const prop in options) {
|
|
12
|
+
this.set(prop, options[prop]);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* @private
|
|
18
|
+
*/
|
|
19
|
+
_setObject(obj: Record<string, any>) {
|
|
20
|
+
for (const prop in obj) {
|
|
21
|
+
this._set(prop, obj[prop]);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* Sets property to a given value. When changing position/dimension -related properties (left, top, scale, angle, etc.) `set` does not update position of object's borders/controls. If you need to update those, call `setCoords()`.
|
|
27
|
+
* @param {String|Object} key Property name or object (if object, iterate over the object properties)
|
|
28
|
+
* @param {Object|Function} value Property value (if function, the value is passed into it and its return value is used as a new one)
|
|
29
|
+
*/
|
|
30
|
+
set(key: string | Record<string, any>, value?: any) {
|
|
31
|
+
if (typeof key === 'object') {
|
|
32
|
+
this._setObject(key);
|
|
33
|
+
} else {
|
|
34
|
+
this._set(key, value);
|
|
35
|
+
}
|
|
36
|
+
return this;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
_set(key: string, value: any) {
|
|
40
|
+
this[key] = value;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* Toggles specified property from `true` to `false` or from `false` to `true`
|
|
45
|
+
* @param {String} property Property to toggle
|
|
46
|
+
*/
|
|
47
|
+
toggle(property: string) {
|
|
48
|
+
const value = this.get(property);
|
|
49
|
+
if (typeof value === 'boolean') {
|
|
50
|
+
this.set(property, !value);
|
|
51
|
+
}
|
|
52
|
+
return this;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* Basic getter
|
|
57
|
+
* @param {String} property Property name
|
|
58
|
+
* @return {*} value of a property
|
|
59
|
+
*/
|
|
60
|
+
get(property: string) {
|
|
61
|
+
return this[property];
|
|
62
|
+
}
|
|
63
|
+
}
|