react-image-markup
Version:
Markup Image with ReactJS (customizable)
257 lines (213 loc) • 27.9 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _fabric = require("fabric");
var _canvasHistory = _interopRequireDefault(require("./canvasHistory"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
var _default = function () {
var drag;
var shape;
var color;
var lineWidth, fillCircle, angle;
var properties;
function Shape(canvas) {
var draggable = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
var type = arguments.length > 2 ? arguments[2] : undefined;
var params = arguments.length > 3 ? arguments[3] : undefined;
if (!draggable) {
drag = false;
return Shape;
}
if (color && color !== params.stroke) {
color = params.stroke;
shape = type;
new Shape(canvas, true, shape, params);
return Shape;
}
if (shape && shape !== type) {
shape = type;
drag = true;
new Shape(canvas, true, shape, params);
return Shape;
}
properties = params;
if (properties) {
fillCircle = properties.fill;
color = properties.stroke;
lineWidth = properties.strokeWidth;
angle = properties.angle;
}
this.canvas = canvas;
this.className = 'Shape';
this.isDrawing = false;
this.origX = 0;
this.origY = 0;
drag = draggable;
shape = type;
this.bindEvents();
}
Shape.prototype.bindEvents = function () {
var inst = this;
document.onkeydown = function (e) {
if (e.which === 46 || e.keycode === 46) {
inst.canvas.getActiveObjects().forEach(function (obj) {
inst.canvas.remove(obj);
});
}
inst.canvas.renderAll();
};
inst.selectable = true;
inst.canvas.off('mouse:down');
inst.canvas.on('mouse:down', function (o) {
inst.onMouseDown(o);
});
inst.canvas.on('mouse:move', function (o) {
inst.onMouseMove(o);
});
inst.canvas.on('mouse:up', function (o) {
inst.onMouseUp(o);
});
inst.canvas.on('object:moving', function () {
inst.disable();
});
};
Shape.prototype.onMouseUp = function () {
var inst = this;
if (!inst.isEnable()) {
return;
}
if (drag) {
inst.canvas.getObjects().forEach(function (object, index, array) {
if (index === array.length - 1) {
if (inst.canvas.getActiveObject() && inst.canvas.getActiveObject()._objects && inst.canvas.getActiveObject()._objects.length > 1) {
inst.canvas.setActiveObject(object);
}
}
});
if (inst.canvas.getActiveObject()) {
inst.canvas.getActiveObject().hasControls = false;
inst.canvas.getActiveObject().hasBorders = false;
inst.canvas.getActiveObject().lockMovementX = true;
inst.canvas.getActiveObject().lockMovementY = true;
inst.canvas.getActiveObject().lockUniScaling = true;
}
inst.canvas.renderAll();
}
new _canvasHistory["default"](inst.canvas);
inst.disable();
};
Shape.prototype.onMouseMove = function (o) {
var inst = this;
if (!inst.isEnable()) {
return;
}
inst.canvas.selection = false;
var pointer = inst.canvas.getPointer(o.e);
var activeObj;
if (inst.canvas.getActiveObject()) {
activeObj = inst.canvas.getActiveObject();
activeObj.stroke = color;
activeObj.strokeWidth = lineWidth;
activeObj.fill = fillCircle;
activeObj.noScaleCache = false;
activeObj.strokeUniform = true;
}
if (this.origX > pointer.x) {
activeObj.set({
left: Math.abs(pointer.x)
});
}
if (this.origY > pointer.y) {
activeObj.set({
top: Math.abs(pointer.y)
});
}
if (shape === "rect") {
activeObj.set({
width: Math.abs(this.origX - pointer.x)
});
activeObj.set({
height: Math.abs(this.origY - pointer.y)
});
}
if (shape === "circle") {
activeObj.set({
rx: Math.abs(this.origX - pointer.x) / 2
});
activeObj.set({
ry: Math.abs(this.origY - pointer.y) / 2
});
}
activeObj.setCoords();
inst.canvas.renderAll();
};
Shape.prototype.onMouseDown = function (o) {
var inst = this;
if (!drag) {
if (inst.canvas.getActiveObject()) {
inst.canvas.getActiveObject().hasControls = true;
inst.canvas.getActiveObject().hasBorders = true;
inst.canvas.getActiveObject().lockMovementX = false;
inst.canvas.getActiveObject().lockMovementY = false;
inst.canvas.getActiveObject().lockUniScaling = false;
inst.canvas.renderAll();
}
inst.disable();
return;
}
inst.enable();
if (inst.canvas.getActiveObject()) {
inst.canvas.getActiveObject().hasControls = false;
inst.canvas.getActiveObject().hasBorders = false;
inst.canvas.getActiveObject().lockMovementX = true;
inst.canvas.getActiveObject().lockMovementY = true;
inst.canvas.getActiveObject().lockUniScaling = true;
inst.canvas.renderAll();
}
var pointer = inst.canvas.getPointer(o.e);
this.origX = pointer.x;
this.origY = pointer.y;
if (shape === "rect") {
var rect = new _fabric.fabric.Rect({
left: this.origX,
top: this.origY,
originX: 'left',
originY: 'top',
width: pointer.x - this.origX,
height: pointer.y - this.origY,
angle: angle,
fill: fillCircle,
transparentCorners: false,
stroke: color,
strokeWidth: lineWidth
});
inst.canvas.add(rect).setActiveObject(rect);
}
if (shape === "circle") {
var circle = new _fabric.fabric.Ellipse({
top: this.origY,
left: this.origX,
rx: 0,
ry: 0,
transparentCorners: false,
hasBorders: true,
hasControls: true
});
inst.canvas.add(circle).setActiveObject(circle);
}
};
Shape.prototype.isEnable = function () {
return this.isDrawing;
};
Shape.prototype.enable = function () {
this.isDrawing = true;
};
Shape.prototype.disable = function () {
this.isDrawing = false;
};
return Shape;
}();
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/assets/js/shape.js"],"names":["drag","shape","color","lineWidth","fillCircle","angle","properties","Shape","canvas","draggable","type","params","stroke","fill","strokeWidth","className","isDrawing","origX","origY","bindEvents","prototype","inst","document","onkeydown","e","which","keycode","getActiveObjects","forEach","obj","remove","renderAll","selectable","off","on","o","onMouseDown","onMouseMove","onMouseUp","disable","isEnable","getObjects","object","index","array","length","getActiveObject","_objects","setActiveObject","hasControls","hasBorders","lockMovementX","lockMovementY","lockUniScaling","CanvasHistory","selection","pointer","getPointer","activeObj","noScaleCache","strokeUniform","x","set","left","Math","abs","y","top","width","height","rx","ry","setCoords","enable","rect","fabric","Rect","originX","originY","transparentCorners","add","circle","Ellipse"],"mappings":"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","sourcesContent":["import {fabric} from 'fabric';\r\nimport CanvasHistory from \"./canvasHistory\";\r\nexport default (function () {\r\n    let drag;\r\n    let shape;\r\n    let color;\r\n    let lineWidth,fillCircle,angle;\r\n    let properties;\r\n    function Shape(canvas,draggable = false,type,params) {     \r\n        if(!draggable){\r\n            drag = false;\r\n            return Shape;\r\n        }\r\n        if(color && color !== params.stroke){\r\n            color = params.stroke;\r\n            shape = type;\r\n            new Shape(canvas,true,shape,params)\r\n            return Shape;\r\n        }\r\n        if((shape && shape !== type)){\r\n            shape = type;\r\n            drag = true;\r\n            new Shape(canvas,true,shape,params)\r\n            return Shape;\r\n        }\r\n        properties = params;\r\n        if(properties){\r\n            fillCircle = properties.fill;\r\n            color = properties.stroke;\r\n            lineWidth = properties.strokeWidth;\r\n            angle = properties.angle;\r\n        }\r\n        this.canvas = canvas;      \r\n        this.className = 'Shape';\r\n        this.isDrawing = false;\r\n        this.origX = 0;\r\n        this.origY = 0;\r\n\r\n        drag = draggable;\r\n        shape = type;\r\n\r\n        this.bindEvents();\r\n    }\r\n\r\n    Shape.prototype.bindEvents = function () {\r\n        let inst = this;\r\n        document.onkeydown=(e)=>{\r\n            if(e.which === 46 || e.keycode === 46){\r\n                inst.canvas.getActiveObjects().forEach((obj) => {\r\n                    inst.canvas.remove(obj)\r\n                });\r\n            }\r\n            inst.canvas.renderAll()\r\n        };\r\n        inst.selectable = true;\r\n                inst.canvas.off('mouse:down');\r\n                \r\n                inst.canvas.on('mouse:down', function (o) {\r\n                    inst.onMouseDown(o);\r\n                });\r\n                inst.canvas.on('mouse:move', function (o) {\r\n                    inst.onMouseMove(o);\r\n                });\r\n                inst.canvas.on('mouse:up', function (o) {\r\n                    inst.onMouseUp(o);\r\n                });\r\n                inst.canvas.on('object:moving', function () {\r\n                    inst.disable();\r\n                });\r\n                \r\n\r\n    };\r\n    Shape.prototype.onMouseUp = function () {\r\n\r\n        let inst = this;\r\n        if (!inst.isEnable()) {\r\n            return;\r\n        }\r\n        if(drag){\r\n            inst.canvas.getObjects().forEach(function(object,index,array) {\r\n                if (index === (array.length -1)) {\r\n                    if(inst.canvas.getActiveObject() && inst.canvas.getActiveObject()._objects && inst.canvas.getActiveObject()._objects.length > 1){\r\n                        inst.canvas.setActiveObject(object);\r\n\r\n                    }\r\n                }\r\n            });\r\n            if(inst.canvas.getActiveObject()){\r\n                inst.canvas.getActiveObject().hasControls = false;\r\n                inst.canvas.getActiveObject().hasBorders = false;\r\n                inst.canvas.getActiveObject().lockMovementX = true;\r\n                inst.canvas.getActiveObject().lockMovementY = true;\r\n                inst.canvas.getActiveObject().lockUniScaling = true;\r\n            }\r\n            inst.canvas.renderAll();\r\n        }\r\n        new CanvasHistory(inst.canvas)\r\n        inst.disable();\r\n\r\n    };\r\n    Shape.prototype.onMouseMove = function (o) {\r\n        let inst = this;\r\n        if (!inst.isEnable()) {\r\n            return;\r\n        }\r\n        inst.canvas.selection = false;\r\n        let pointer = inst.canvas.getPointer(o.e);\r\n        let activeObj;\r\n        if(inst.canvas.getActiveObject()){\r\n            activeObj = inst.canvas.getActiveObject();\r\n            activeObj.stroke = color;\r\n            activeObj.strokeWidth = lineWidth;\r\n            activeObj.fill = fillCircle;\r\n            activeObj.noScaleCache = false;\r\n            activeObj.strokeUniform = true;\r\n        }\r\n\r\n        if (this.origX > pointer.x) {\r\n            activeObj.set({\r\n                left: Math.abs(pointer.x)\r\n            });\r\n        }\r\n        if (this.origY > pointer.y) {\r\n            activeObj.set({\r\n                top: Math.abs(pointer.y)\r\n            });\r\n        }\r\n        if(shape === \"rect\"){\r\n            activeObj.set({\r\n                width: Math.abs(this.origX - pointer.x)\r\n            });\r\n            activeObj.set({\r\n                height: Math.abs(this.origY - pointer.y)\r\n            });\r\n        }\r\n        if(shape === \"circle\"){\r\n            activeObj.set({\r\n                rx: Math.abs(this.origX - pointer.x) / 2\r\n            });\r\n            activeObj.set({\r\n                ry: Math.abs(this.origY - pointer.y) / 2\r\n            });\r\n        }\r\n        activeObj.setCoords();\r\n        inst.canvas.renderAll();\r\n    };\r\n\r\n    Shape.prototype.onMouseDown = function (o) {\r\n        \r\n        let inst = this;   \r\n        if(!drag){\r\n            \r\n            if( inst.canvas.getActiveObject()){\r\n                inst.canvas.getActiveObject().hasControls = true;\r\n                inst.canvas.getActiveObject().hasBorders = true;\r\n                inst.canvas.getActiveObject().lockMovementX = false;\r\n                inst.canvas.getActiveObject().lockMovementY = false;\r\n                inst.canvas.getActiveObject().lockUniScaling = false;\r\n                inst.canvas.renderAll();\r\n            }\r\n            inst.disable();\r\n            return;\r\n        }\r\n            inst.enable();\r\n            \r\n            if(inst.canvas.getActiveObject()){\r\n                inst.canvas.getActiveObject().hasControls = false;\r\n                inst.canvas.getActiveObject().hasBorders = false;\r\n                inst.canvas.getActiveObject().lockMovementX = true;\r\n                inst.canvas.getActiveObject().lockMovementY = true;\r\n                inst.canvas.getActiveObject().lockUniScaling = true;\r\n                inst.canvas.renderAll();\r\n            }\r\n            let pointer = inst.canvas.getPointer(o.e);\r\n            this.origX = pointer.x;\r\n            this.origY = pointer.y;\r\n            if(shape === \"rect\"){\r\n                let rect = new fabric.Rect({\r\n                    left: this.origX,\r\n                    top: this.origY,\r\n                    originX: 'left',\r\n                    originY: 'top',\r\n                    width: pointer.x - this.origX,\r\n                    height: pointer.y - this.origY,\r\n                    angle: angle,\r\n                    fill: fillCircle,\r\n                    transparentCorners: false,\r\n                    stroke: color,\r\n                    strokeWidth: lineWidth\r\n                });\r\n                inst.canvas.add(rect).setActiveObject(rect);\r\n            }\r\n            if(shape === \"circle\"){\r\n                let circle = new fabric.Ellipse({\r\n                    top: this.origY,\r\n                    left: this.origX,\r\n                    rx: 0,\r\n                    ry: 0,\r\n                    transparentCorners: false,\r\n                    hasBorders: true,\r\n                    hasControls: true,\r\n                });\r\n                inst.canvas.add(circle).setActiveObject(circle);\r\n            }\r\n    };\r\n    Shape.prototype.isEnable = function () {\r\n        return this.isDrawing;\r\n    }\r\n\r\n    Shape.prototype.enable = function () {\r\n        this.isDrawing = true;\r\n    }\r\n\r\n    Shape.prototype.disable = function () {\r\n        this.isDrawing = false;\r\n    }\r\n    return Shape;\r\n}());\r\n"]}