react-image-markup
Version:
Markup Image with ReactJS (customizable)
239 lines (197 loc) • 27.2 kB
JavaScript
"use strict";
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 }; }
_fabric.fabric.LineArrow = _fabric.fabric.util.createClass(_fabric.fabric.Line, {
type: 'lineArrow',
initialize: function initialize(element, options) {
options || (options = {});
this.callSuper('initialize', element, options);
},
toObject: function toObject() {
return _fabric.fabric.util.object.extend(this.callSuper('toObject'));
},
_render: function _render(ctx) {
this.ctx = ctx;
this.callSuper('_render', ctx);
var p = this.calcLinePoints();
var xDiff = this.x2 - this.x1;
var yDiff = this.y2 - this.y1;
var angle = Math.atan2(yDiff, xDiff);
this.drawArrow(angle, p.x2, p.y2, this.heads[0]);
ctx.save();
xDiff = -this.x2 + this.x1;
yDiff = -this.y2 + this.y1;
angle = Math.atan2(yDiff, xDiff);
this.drawArrow(angle, p.x1, p.y1, this.heads[1]);
},
drawArrow: function drawArrow(angle, xPos, yPos, head) {
this.ctx.save();
if (head) {
this.ctx.translate(xPos, yPos);
this.ctx.rotate(angle);
this.ctx.beginPath();
this.ctx.moveTo(10, 0);
this.ctx.lineTo(-15, 15);
this.ctx.lineTo(-15, -15);
this.ctx.closePath();
}
this.ctx.fillStyle = this.stroke;
this.ctx.fill();
this.ctx.restore();
}
});
_fabric.fabric.LineArrow.fromObject = function (object, callback) {
callback && callback(new _fabric.fabric.LineArrow([object.x1, object.y1, object.x2, object.y2], object));
};
_fabric.fabric.LineArrow.async = true;
_fabric.fabric.LineArrow.fromObject = function (object, callback) {
callback && callback(new _fabric.fabric.LineArrow([object.x1, object.y1, object.x2, object.y2], object));
};
_fabric.fabric.LineArrow.async = true;
var _default = function () {
var drag;
var color;
var lineWidth;
var properties;
function Arrow(canvas) {
var draggable = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
var params = arguments.length > 2 ? arguments[2] : undefined;
if (!draggable) {
drag = false;
return Arrow;
}
if (color && color !== params.stroke) {
color = params.stroke;
new Arrow(canvas, draggable, params);
return Arrow;
}
properties = params;
if (properties) {
color = params.stroke;
lineWidth = params.strokeWidth;
}
this.canvas = canvas;
this.className = 'Arrow';
this.isDrawing = false;
this.bindEvents();
drag = draggable;
}
Arrow.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();
});
};
Arrow.prototype.onMouseUp = function () {
var inst = this;
if (!inst.isEnable()) {
return;
}
if (drag) {
this.line.set({
dirty: true,
objectCaching: true
});
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();
};
Arrow.prototype.onMouseMove = function (o) {
var inst = this;
inst.canvas.selection = false;
if (!inst.isEnable()) {
return;
}
var pointer = inst.canvas.getPointer(o.e);
var activeObj = inst.canvas.getActiveObject();
activeObj.set({
x2: pointer.x,
y2: pointer.y
});
activeObj.setCoords();
inst.canvas.renderAll();
};
Arrow.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);
var points = [pointer.x, pointer.y, pointer.x, pointer.y];
this.line = new _fabric.fabric.LineArrow(points, {
strokeWidth: lineWidth,
fill: color,
stroke: color,
originX: 'center',
originY: 'center',
hasBorders: false,
hasControls: false,
objectCaching: false,
perPixelTargetFind: true,
heads: [1, 0]
});
inst.canvas.add(this.line).setActiveObject(this.line);
};
Arrow.prototype.isEnable = function () {
return this.isDrawing;
};
Arrow.prototype.enable = function () {
this.isDrawing = true;
};
Arrow.prototype.disable = function () {
this.isDrawing = false;
};
return Arrow;
}();
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/assets/js/arrow.js"],"names":["fabric","LineArrow","util","createClass","Line","type","initialize","element","options","callSuper","toObject","object","extend","_render","ctx","p","calcLinePoints","xDiff","x2","x1","yDiff","y2","y1","angle","Math","atan2","drawArrow","heads","save","xPos","yPos","head","translate","rotate","beginPath","moveTo","lineTo","closePath","fillStyle","stroke","fill","restore","fromObject","callback","async","drag","color","lineWidth","properties","Arrow","canvas","draggable","params","strokeWidth","className","isDrawing","bindEvents","prototype","inst","document","onkeydown","e","which","keycode","getActiveObjects","forEach","obj","remove","renderAll","selectable","off","on","o","onMouseDown","onMouseMove","onMouseUp","disable","isEnable","line","set","dirty","objectCaching","getActiveObject","hasControls","hasBorders","lockMovementX","lockMovementY","lockUniScaling","CanvasHistory","selection","pointer","getPointer","activeObj","x","y","setCoords","enable","points","originX","originY","perPixelTargetFind","add","setActiveObject"],"mappings":";;;;;;;AAAA;;AACA;;;;AACAA,eAAOC,SAAP,GAAmBD,eAAOE,IAAP,CAAYC,WAAZ,CAAwBH,eAAOI,IAA/B,EAAqC;AAEpDC,EAAAA,IAAI,EAAE,WAF8C;AAIpDC,EAAAA,UAAU,EAAE,oBAASC,OAAT,EAAkBC,OAAlB,EAA2B;AACnCA,IAAAA,OAAO,KAAKA,OAAO,GAAG,EAAf,CAAP;AACA,SAAKC,SAAL,CAAe,YAAf,EAA6BF,OAA7B,EAAsCC,OAAtC;AACH,GAPmD;AASpDE,EAAAA,QAAQ,EAAE,oBAAW;AACjB,WAAOV,eAAOE,IAAP,CAAYS,MAAZ,CAAmBC,MAAnB,CAA0B,KAAKH,SAAL,CAAe,UAAf,CAA1B,CAAP;AACH,GAXmD;AAapDI,EAAAA,OAAO,EAAE,iBAASC,GAAT,EAAc;AACnB,SAAKA,GAAL,GAAWA,GAAX;AACA,SAAKL,SAAL,CAAe,SAAf,EAA0BK,GAA1B;AACA,QAAIC,CAAC,GAAG,KAAKC,cAAL,EAAR;AACA,QAAIC,KAAK,GAAG,KAAKC,EAAL,GAAU,KAAKC,EAA3B;AACA,QAAIC,KAAK,GAAG,KAAKC,EAAL,GAAU,KAAKC,EAA3B;AACA,QAAIC,KAAK,GAAGC,IAAI,CAACC,KAAL,CAAWL,KAAX,EAAkBH,KAAlB,CAAZ;AACA,SAAKS,SAAL,CAAeH,KAAf,EAAsBR,CAAC,CAACG,EAAxB,EAA4BH,CAAC,CAACM,EAA9B,EAAkC,KAAKM,KAAL,CAAW,CAAX,CAAlC;AACAb,IAAAA,GAAG,CAACc,IAAJ;AACAX,IAAAA,KAAK,GAAG,CAAC,KAAKC,EAAN,GAAW,KAAKC,EAAxB;AACAC,IAAAA,KAAK,GAAG,CAAC,KAAKC,EAAN,GAAW,KAAKC,EAAxB;AACAC,IAAAA,KAAK,GAAGC,IAAI,CAACC,KAAL,CAAWL,KAAX,EAAkBH,KAAlB,CAAR;AACA,SAAKS,SAAL,CAAeH,KAAf,EAAsBR,CAAC,CAACI,EAAxB,EAA4BJ,CAAC,CAACO,EAA9B,EAAiC,KAAKK,KAAL,CAAW,CAAX,CAAjC;AACH,GA1BmD;AA4BpDD,EAAAA,SAAS,EAAE,mBAASH,KAAT,EAAgBM,IAAhB,EAAsBC,IAAtB,EAA4BC,IAA5B,EAAkC;AACzC,SAAKjB,GAAL,CAASc,IAAT;;AAEA,QAAIG,IAAJ,EAAU;AACN,WAAKjB,GAAL,CAASkB,SAAT,CAAmBH,IAAnB,EAAyBC,IAAzB;AACA,WAAKhB,GAAL,CAASmB,MAAT,CAAgBV,KAAhB;AACA,WAAKT,GAAL,CAASoB,SAAT;AACA,WAAKpB,GAAL,CAASqB,MAAT,CAAgB,EAAhB,EAAoB,CAApB;AACA,WAAKrB,GAAL,CAASsB,MAAT,CAAgB,CAAC,EAAjB,EAAqB,EAArB;AACA,WAAKtB,GAAL,CAASsB,MAAT,CAAgB,CAAC,EAAjB,EAAqB,CAAC,EAAtB;AACA,WAAKtB,GAAL,CAASuB,SAAT;AACH;;AAED,SAAKvB,GAAL,CAASwB,SAAT,GAAqB,KAAKC,MAA1B;AACA,SAAKzB,GAAL,CAAS0B,IAAT;AACA,SAAK1B,GAAL,CAAS2B,OAAT;AACH;AA5CmD,CAArC,CAAnB;;AAiDAzC,eAAOC,SAAP,CAAiByC,UAAjB,GAA8B,UAAS/B,MAAT,EAAiBgC,QAAjB,EAA2B;AACrDA,EAAAA,QAAQ,IAAIA,QAAQ,CAAC,IAAI3C,eAAOC,SAAX,CAAqB,CAACU,MAAM,CAACQ,EAAR,EAAYR,MAAM,CAACW,EAAnB,EAAuBX,MAAM,CAACO,EAA9B,EAAkCP,MAAM,CAACU,EAAzC,CAArB,EAAmEV,MAAnE,CAAD,CAApB;AACH,CAFD;;AAGAX,eAAOC,SAAP,CAAiB2C,KAAjB,GAAyB,IAAzB;;AACA5C,eAAOC,SAAP,CAAiByC,UAAjB,GAA8B,UAAS/B,MAAT,EAAiBgC,QAAjB,EAA2B;AACrDA,EAAAA,QAAQ,IAAIA,QAAQ,CAAC,IAAI3C,eAAOC,SAAX,CAAqB,CAACU,MAAM,CAACQ,EAAR,EAAYR,MAAM,CAACW,EAAnB,EAAuBX,MAAM,CAACO,EAA9B,EAAkCP,MAAM,CAACU,EAAzC,CAArB,EAAmEV,MAAnE,CAAD,CAApB;AACH,CAFD;;AAGAX,eAAOC,SAAP,CAAiB2C,KAAjB,GAAyB,IAAzB;;eAEgB,YAAY;AACxB,MAAIC,IAAJ;AACA,MAAIC,KAAJ;AACA,MAAIC,SAAJ;AACA,MAAIC,UAAJ;;AACA,WAASC,KAAT,CAAeC,MAAf,EAAgD;AAAA,QAA1BC,SAA0B,uEAAd,KAAc;AAAA,QAARC,MAAQ;;AAE5C,QAAG,CAACD,SAAJ,EAAc;AACVN,MAAAA,IAAI,GAAG,KAAP;AACA,aAAOI,KAAP;AACH;;AAED,QAAGH,KAAK,IAAIA,KAAK,KAAKM,MAAM,CAACb,MAA7B,EAAoC;AAChCO,MAAAA,KAAK,GAAGM,MAAM,CAACb,MAAf;AACA,UAAIU,KAAJ,CAAUC,MAAV,EAAiBC,SAAjB,EAA2BC,MAA3B;AACA,aAAOH,KAAP;AACH;;AAEDD,IAAAA,UAAU,GAAGI,MAAb;;AACA,QAAGJ,UAAH,EAAc;AACVF,MAAAA,KAAK,GAAGM,MAAM,CAACb,MAAf;AACAQ,MAAAA,SAAS,GAAGK,MAAM,CAACC,WAAnB;AACH;;AACD,SAAKH,MAAL,GAAcA,MAAd;AACA,SAAKI,SAAL,GAAiB,OAAjB;AACA,SAAKC,SAAL,GAAiB,KAAjB;AACA,SAAKC,UAAL;AACAX,IAAAA,IAAI,GAAGM,SAAP;AAEH;;AAEDF,EAAAA,KAAK,CAACQ,SAAN,CAAgBD,UAAhB,GAA6B,YAAY;AACrC,QAAIE,IAAI,GAAG,IAAX;;AACAC,IAAAA,QAAQ,CAACC,SAAT,GAAmB,UAACC,CAAD,EAAK;AACpB,UAAGA,CAAC,CAACC,KAAF,KAAY,EAAZ,IAAkBD,CAAC,CAACE,OAAF,KAAc,EAAnC,EAAsC;AAClCL,QAAAA,IAAI,CAACR,MAAL,CAAYc,gBAAZ,GAA+BC,OAA/B,CAAuC,UAACC,GAAD,EAAS;AAC5CR,UAAAA,IAAI,CAACR,MAAL,CAAYiB,MAAZ,CAAmBD,GAAnB;AACH,SAFD;AAGH;;AACDR,MAAAA,IAAI,CAACR,MAAL,CAAYkB,SAAZ;AACH,KAPD;;AAQAV,IAAAA,IAAI,CAACW,UAAL,GAAkB,IAAlB;AAEIX,IAAAA,IAAI,CAACR,MAAL,CAAYoB,GAAZ,CAAgB,YAAhB;AACAZ,IAAAA,IAAI,CAACR,MAAL,CAAYqB,EAAZ,CAAe,YAAf,EAA6B,UAAUC,CAAV,EAAa;AACtCd,MAAAA,IAAI,CAACe,WAAL,CAAiBD,CAAjB;AACH,KAFD;AAGAd,IAAAA,IAAI,CAACR,MAAL,CAAYqB,EAAZ,CAAe,YAAf,EAA6B,UAAUC,CAAV,EAAa;AACtCd,MAAAA,IAAI,CAACgB,WAAL,CAAiBF,CAAjB;AACH,KAFD;AAGAd,IAAAA,IAAI,CAACR,MAAL,CAAYqB,EAAZ,CAAe,UAAf,EAA2B,UAAUC,CAAV,EAAa;AACpCd,MAAAA,IAAI,CAACiB,SAAL,CAAeH,CAAf;AAEH,KAHD;AAIAd,IAAAA,IAAI,CAACR,MAAL,CAAYqB,EAAZ,CAAe,eAAf,EAAgC,YAAY;AACxCb,MAAAA,IAAI,CAACkB,OAAL;AACH,KAFD;AAGP,GA1BD;;AA2BA3B,EAAAA,KAAK,CAACQ,SAAN,CAAgBkB,SAAhB,GAA4B,YAAY;AACpC,QAAIjB,IAAI,GAAG,IAAX;;AACA,QAAI,CAACA,IAAI,CAACmB,QAAL,EAAL,EAAsB;AAClB;AACH;;AACD,QAAGhC,IAAH,EAAQ;AACJ,WAAKiC,IAAL,CAAUC,GAAV,CAAc;AACVC,QAAAA,KAAK,EAAE,IADG;AAEVC,QAAAA,aAAa,EAAE;AAFL,OAAd;;AAIA,UAAGvB,IAAI,CAACR,MAAL,CAAYgC,eAAZ,EAAH,EAAiC;AAC7BxB,QAAAA,IAAI,CAACR,MAAL,CAAYgC,eAAZ,GAA8BC,WAA9B,GAA4C,KAA5C;AACAzB,QAAAA,IAAI,CAACR,MAAL,CAAYgC,eAAZ,GAA8BE,UAA9B,GAA2C,KAA3C;AACA1B,QAAAA,IAAI,CAACR,MAAL,CAAYgC,eAAZ,GAA8BG,aAA9B,GAA8C,IAA9C;AACA3B,QAAAA,IAAI,CAACR,MAAL,CAAYgC,eAAZ,GAA8BI,aAA9B,GAA8C,IAA9C;AACA5B,QAAAA,IAAI,CAACR,MAAL,CAAYgC,eAAZ,GAA8BK,cAA9B,GAA+C,IAA/C;AACH;;AACD7B,MAAAA,IAAI,CAACR,MAAL,CAAYkB,SAAZ;AACA,UAAIoB,yBAAJ,CAAkB9B,IAAI,CAACR,MAAvB;AACH;;AACDQ,IAAAA,IAAI,CAACkB,OAAL;AACH,GArBD;;AAsBA3B,EAAAA,KAAK,CAACQ,SAAN,CAAgBiB,WAAhB,GAA8B,UAAUF,CAAV,EAAa;AACvC,QAAId,IAAI,GAAG,IAAX;AACAA,IAAAA,IAAI,CAACR,MAAL,CAAYuC,SAAZ,GAAwB,KAAxB;;AACA,QAAI,CAAC/B,IAAI,CAACmB,QAAL,EAAL,EAAsB;AAClB;AACH;;AACD,QAAIa,OAAO,GAAGhC,IAAI,CAACR,MAAL,CAAYyC,UAAZ,CAAuBnB,CAAC,CAACX,CAAzB,CAAd;AACA,QAAI+B,SAAS,GAAGlC,IAAI,CAACR,MAAL,CAAYgC,eAAZ,EAAhB;AACAU,IAAAA,SAAS,CAACb,GAAV,CAAc;AACV7D,MAAAA,EAAE,EAAEwE,OAAO,CAACG,CADF;AAEVxE,MAAAA,EAAE,EAAEqE,OAAO,CAACI;AAFF,KAAd;AAIAF,IAAAA,SAAS,CAACG,SAAV;AACArC,IAAAA,IAAI,CAACR,MAAL,CAAYkB,SAAZ;AACH,GAdD;;AAgBAnB,EAAAA,KAAK,CAACQ,SAAN,CAAgBgB,WAAhB,GAA8B,UAAUD,CAAV,EAAa;AAEvC,QAAId,IAAI,GAAG,IAAX;;AACA,QAAG,CAACb,IAAJ,EAAS;AACL,UAAIa,IAAI,CAACR,MAAL,CAAYgC,eAAZ,EAAJ,EAAkC;AAC9BxB,QAAAA,IAAI,CAACR,MAAL,CAAYgC,eAAZ,GAA8BC,WAA9B,GAA4C,IAA5C;AACAzB,QAAAA,IAAI,CAACR,MAAL,CAAYgC,eAAZ,GAA8BE,UAA9B,GAA2C,IAA3C;AACA1B,QAAAA,IAAI,CAACR,MAAL,CAAYgC,eAAZ,GAA8BG,aAA9B,GAA8C,KAA9C;AACA3B,QAAAA,IAAI,CAACR,MAAL,CAAYgC,eAAZ,GAA8BI,aAA9B,GAA8C,KAA9C;AACA5B,QAAAA,IAAI,CAACR,MAAL,CAAYgC,eAAZ,GAA8BK,cAA9B,GAA+C,KAA/C;AACA7B,QAAAA,IAAI,CAACR,MAAL,CAAYkB,SAAZ;AACH;;AACDV,MAAAA,IAAI,CAACkB,OAAL;AACA;AACH;;AACDlB,IAAAA,IAAI,CAACsC,MAAL;;AACA,QAAGtC,IAAI,CAACR,MAAL,CAAYgC,eAAZ,EAAH,EAAiC;AAC7BxB,MAAAA,IAAI,CAACR,MAAL,CAAYgC,eAAZ,GAA8BC,WAA9B,GAA4C,KAA5C;AACAzB,MAAAA,IAAI,CAACR,MAAL,CAAYgC,eAAZ,GAA8BE,UAA9B,GAA2C,KAA3C;AACA1B,MAAAA,IAAI,CAACR,MAAL,CAAYgC,eAAZ,GAA8BG,aAA9B,GAA8C,IAA9C;AACA3B,MAAAA,IAAI,CAACR,MAAL,CAAYgC,eAAZ,GAA8BI,aAA9B,GAA8C,IAA9C;AACA5B,MAAAA,IAAI,CAACR,MAAL,CAAYgC,eAAZ,GAA8BK,cAA9B,GAA+C,IAA/C;AACA7B,MAAAA,IAAI,CAACR,MAAL,CAAYkB,SAAZ;AACH;;AACD,QAAIsB,OAAO,GAAGhC,IAAI,CAACR,MAAL,CAAYyC,UAAZ,CAAuBnB,CAAC,CAACX,CAAzB,CAAd;AACA,QAAIoC,MAAM,GAAG,CAACP,OAAO,CAACG,CAAT,EAAYH,OAAO,CAACI,CAApB,EAAuBJ,OAAO,CAACG,CAA/B,EAAkCH,OAAO,CAACI,CAA1C,CAAb;AACA,SAAKhB,IAAL,GAAY,IAAI9E,eAAOC,SAAX,CAAqBgG,MAArB,EAA6B;AACrC5C,MAAAA,WAAW,EAAEN,SADwB;AAErCP,MAAAA,IAAI,EAAEM,KAF+B;AAGrCP,MAAAA,MAAM,EAAEO,KAH6B;AAIrCoD,MAAAA,OAAO,EAAE,QAJ4B;AAKrCC,MAAAA,OAAO,EAAE,QAL4B;AAMrCf,MAAAA,UAAU,EAAE,KANyB;AAOrCD,MAAAA,WAAW,EAAE,KAPwB;AAQrCF,MAAAA,aAAa,EAAE,KARsB;AASrCmB,MAAAA,kBAAkB,EAAE,IATiB;AAUrCzE,MAAAA,KAAK,EAAE,CAAC,CAAD,EAAI,CAAJ;AAV8B,KAA7B,CAAZ;AAaA+B,IAAAA,IAAI,CAACR,MAAL,CAAYmD,GAAZ,CAAgB,KAAKvB,IAArB,EAA2BwB,eAA3B,CAA2C,KAAKxB,IAAhD;AAEH,GAzCD;;AA2CA7B,EAAAA,KAAK,CAACQ,SAAN,CAAgBoB,QAAhB,GAA2B,YAAY;AACnC,WAAO,KAAKtB,SAAZ;AACH,GAFD;;AAIAN,EAAAA,KAAK,CAACQ,SAAN,CAAgBuC,MAAhB,GAAyB,YAAY;AACjC,SAAKzC,SAAL,GAAiB,IAAjB;AACH,GAFD;;AAIAN,EAAAA,KAAK,CAACQ,SAAN,CAAgBmB,OAAhB,GAA0B,YAAY;AAClC,SAAKrB,SAAL,GAAiB,KAAjB;AACH,GAFD;;AAIA,SAAON,KAAP;AACH,CAxJe,E","sourcesContent":["import {fabric} from 'fabric';\r\nimport CanvasHistory from \"./canvasHistory\";\r\nfabric.LineArrow = fabric.util.createClass(fabric.Line, {\r\n\r\n    type: 'lineArrow',\r\n\r\n    initialize: function(element, options) {\r\n        options || (options = {});\r\n        this.callSuper('initialize', element, options);\r\n    },\r\n\r\n    toObject: function() {\r\n        return fabric.util.object.extend(this.callSuper('toObject'));\r\n    },\r\n\r\n    _render: function(ctx) {\r\n        this.ctx = ctx;\r\n        this.callSuper('_render', ctx);\r\n        let p = this.calcLinePoints();\r\n        let xDiff = this.x2 - this.x1;\r\n        let yDiff = this.y2 - this.y1;\r\n        let angle = Math.atan2(yDiff, xDiff);\r\n        this.drawArrow(angle, p.x2, p.y2, this.heads[0]);\r\n        ctx.save();\r\n        xDiff = -this.x2 + this.x1;\r\n        yDiff = -this.y2 + this.y1;\r\n        angle = Math.atan2(yDiff, xDiff);\r\n        this.drawArrow(angle, p.x1, p.y1,this.heads[1]);\r\n    },\r\n\r\n    drawArrow: function(angle, xPos, yPos, head) {\r\n        this.ctx.save();\r\n\r\n        if (head) {\r\n            this.ctx.translate(xPos, yPos);\r\n            this.ctx.rotate(angle);\r\n            this.ctx.beginPath();\r\n            this.ctx.moveTo(10, 0);\r\n            this.ctx.lineTo(-15, 15);\r\n            this.ctx.lineTo(-15, -15);\r\n            this.ctx.closePath();\r\n        }\r\n\r\n        this.ctx.fillStyle = this.stroke;\r\n        this.ctx.fill();\r\n        this.ctx.restore();\r\n    }\r\n});\r\n\r\n\r\n\r\nfabric.LineArrow.fromObject = function(object, callback) {\r\n    callback && callback(new fabric.LineArrow([object.x1, object.y1, object.x2, object.y2], object));\r\n};\r\nfabric.LineArrow.async = true;\r\nfabric.LineArrow.fromObject = function(object, callback) {\r\n    callback && callback(new fabric.LineArrow([object.x1, object.y1, object.x2, object.y2], object));\r\n};\r\nfabric.LineArrow.async = true;\r\n\r\nexport default (function () {\r\n    let drag;\r\n    let color;\r\n    let lineWidth;\r\n    let properties;\r\n    function Arrow(canvas,draggable = false,params) {\r\n\r\n        if(!draggable){\r\n            drag = false;\r\n            return Arrow;\r\n        }\r\n\r\n        if(color && color !== params.stroke){\r\n            color = params.stroke;\r\n            new Arrow(canvas,draggable,params)\r\n            return Arrow;\r\n        }\r\n\r\n        properties = params;\r\n        if(properties){\r\n            color = params.stroke;\r\n            lineWidth = params.strokeWidth;\r\n        }\r\n        this.canvas = canvas;\r\n        this.className = 'Arrow';\r\n        this.isDrawing = false;\r\n        this.bindEvents();\r\n        drag = draggable;\r\n        \r\n    }\r\n\r\n    Arrow.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        \r\n            inst.canvas.off('mouse:down');\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            });\r\n            inst.canvas.on('object:moving', function () {\r\n                inst.disable();\r\n            });\r\n    };\r\n    Arrow.prototype.onMouseUp = function () {\r\n        let inst = this;\r\n        if (!inst.isEnable()) {\r\n            return;         \r\n        }\r\n        if(drag){\r\n            this.line.set({\r\n                dirty: true,\r\n                objectCaching: true\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            new CanvasHistory(inst.canvas)\r\n        }\r\n        inst.disable();\r\n    };\r\n    Arrow.prototype.onMouseMove = function (o) {\r\n        let inst = this;\r\n        inst.canvas.selection = false;\r\n        if (!inst.isEnable()) {\r\n            return;\r\n        }\r\n        let pointer = inst.canvas.getPointer(o.e);\r\n        let activeObj = inst.canvas.getActiveObject();\r\n        activeObj.set({\r\n            x2: pointer.x,\r\n            y2: pointer.y\r\n        });\r\n        activeObj.setCoords();\r\n        inst.canvas.renderAll();\r\n    };\r\n\r\n    Arrow.prototype.onMouseDown = function (o) {\r\n\r\n        let inst = this;\r\n        if(!drag){\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        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        let points = [pointer.x, pointer.y, pointer.x, pointer.y];\r\n        this.line = new fabric.LineArrow(points, {\r\n            strokeWidth: lineWidth,\r\n            fill: color,\r\n            stroke: color,\r\n            originX: 'center',\r\n            originY: 'center',\r\n            hasBorders: false,\r\n            hasControls: false,\r\n            objectCaching: false,\r\n            perPixelTargetFind: true,\r\n            heads: [1, 0]\r\n        });\r\n\r\n        inst.canvas.add(this.line).setActiveObject(this.line);\r\n\r\n    };\r\n\r\n    Arrow.prototype.isEnable = function () {\r\n        return this.isDrawing;\r\n    };\r\n\r\n    Arrow.prototype.enable = function () {\r\n        this.isDrawing = true;\r\n    };\r\n\r\n    Arrow.prototype.disable = function () {\r\n        this.isDrawing = false;\r\n    };\r\n\r\n    return Arrow;\r\n}());\r\n\r\n"]}