@inweb/markup 25.8.16 → 25.8.20

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.
@@ -61,7 +61,14 @@ class KonvaLine {
61
61
  this._ref = ref;
62
62
  return;
63
63
  }
64
- if (!params || !params.points) return;
64
+ if (!params) params = {};
65
+ if (!params.points) params.points = [ {
66
+ x: 50,
67
+ y: 50
68
+ }, {
69
+ x: 100,
70
+ y: 100
71
+ } ];
65
72
  const konvaPoints = [];
66
73
  params.points.forEach((point => konvaPoints.push(point.x, point.y)));
67
74
  this._ref = new Konva.Line({
@@ -163,7 +170,12 @@ class KonvaText {
163
170
  this._ref = ref;
164
171
  return;
165
172
  }
166
- if (!params || !params.position || !params.text) return;
173
+ if (!params) params = {};
174
+ if (!params.position) params.position = {
175
+ x: 100,
176
+ y: 100
177
+ };
178
+ if (!params.text) params.text = "default";
167
179
  this._ref = new Konva.Text({
168
180
  x: params.position.x,
169
181
  y: params.position.y,
@@ -265,7 +277,11 @@ class KonvaRectangle {
265
277
  this._ref = ref;
266
278
  return;
267
279
  }
268
- if (!params || !params.position) return;
280
+ if (!params) params = {};
281
+ if (!params.position) params.position = {
282
+ x: 100,
283
+ y: 100
284
+ };
269
285
  this._ref = new Konva.Rect({
270
286
  stroke: (_a = params.color) !== null && _a !== void 0 ? _a : "#ff0000",
271
287
  strokeWidth: (_b = params.lineWidth) !== null && _b !== void 0 ? _b : 4,
@@ -375,7 +391,15 @@ class KonvaEllipse {
375
391
  this._ref = ref;
376
392
  return;
377
393
  }
378
- if (!params || !params.position || !params.radius) return;
394
+ if (!params) params = {};
395
+ if (!params.position) params.position = {
396
+ x: 100,
397
+ y: 100
398
+ };
399
+ if (!params.radius) params.radius = {
400
+ x: 25,
401
+ y: 25
402
+ };
379
403
  this._ref = new Konva.Ellipse({
380
404
  stroke: (_a = params.color) !== null && _a !== void 0 ? _a : "#ff0000",
381
405
  strokeWidth: (_b = params.lineWidth) !== null && _b !== void 0 ? _b : 4,
@@ -497,7 +521,15 @@ class KonvaArrow {
497
521
  this._ref = ref;
498
522
  return;
499
523
  }
500
- if (!params || !params.start || !params.end) return;
524
+ if (!params) params = {};
525
+ if (!params.start) params.start = {
526
+ x: 50,
527
+ y: 50
528
+ };
529
+ if (!params.end) params.end = {
530
+ x: 100,
531
+ y: 100
532
+ };
501
533
  this._ref = new Konva.Arrow({
502
534
  stroke: (_a = params.color) !== null && _a !== void 0 ? _a : "#ff0000",
503
535
  fill: (_b = params.color) !== null && _b !== void 0 ? _b : "#ff0000",
@@ -593,14 +625,49 @@ class KonvaImage {
593
625
  constructor(params, ref = null) {
594
626
  var _a, _b;
595
627
  this._ratio = 1;
628
+ this.EPSILON = 1e-5;
629
+ this.BASE64_NOT_FOUND = "";
630
+ this.BASE64_HEADER_START = "data:image/";
596
631
  if (ref) {
632
+ if (!ref.src || !ref.src.startsWith(this.BASE64_HEADER_START)) ref.src = this.BASE64_NOT_FOUND;
633
+ if (ref.height() <= this.EPSILON) ref.height(32);
634
+ if (ref.width() <= this.EPSILON) ref.width(32);
597
635
  this._ref = ref;
598
636
  this._canvasImage = ref.image();
599
- this._ratio = this._ref.height() === 0 || this._ref.width() === 0 ? 1 : this._ref.height() / this._ref.width();
637
+ this._ratio = this._ref.height() <= this.EPSILON || this._ref.width() <= this.EPSILON ? 1 : this._ref.height() / this._ref.width();
600
638
  return;
601
639
  }
602
- if (!params || !params.position || !params.src) return;
640
+ if (!params) params = {};
641
+ if (!params.position) params.position = {
642
+ x: 50,
643
+ y: 50
644
+ };
645
+ if (!params.src || !params.src.startsWith(this.BASE64_HEADER_START)) params.src = this.BASE64_NOT_FOUND;
603
646
  this._canvasImage = new Image;
647
+ this._canvasImage.onload = () => {
648
+ this._ref.image(this._canvasImage);
649
+ if (this._ref.height() <= this.EPSILON) this._ref.height(this._canvasImage.height);
650
+ if (this._ref.width() <= this.EPSILON) this._ref.width(this._canvasImage.width);
651
+ this._ratio = this._ref.height() <= this.EPSILON || this._ref.width() <= this.EPSILON ? 1 : this._ref.height() / this._ref.width();
652
+ if ((params.width <= this.EPSILON || params.height <= this.EPSILON) && (params.maxWidth >= this.EPSILON || params.maxWidth >= this.EPSILON)) {
653
+ const heightOutOfCanvas = params.maxHeight - this._canvasImage.height;
654
+ const widthOutOfCanvas = params.maxWidth - this._canvasImage.width;
655
+ if (heightOutOfCanvas <= this.EPSILON || widthOutOfCanvas <= this.EPSILON) {
656
+ if (widthOutOfCanvas <= this.EPSILON && widthOutOfCanvas < heightOutOfCanvas / this._ratio) {
657
+ this._ref.height(params.maxWidth * this._ratio);
658
+ this._ref.width(params.maxWidth);
659
+ } else {
660
+ this._ref.width(params.maxHeight / this._ratio);
661
+ this._ref.height(params.maxHeight);
662
+ }
663
+ }
664
+ }
665
+ };
666
+ this._canvasImage.onerror = () => {
667
+ this._canvasImage.onerror = function() {};
668
+ this._canvasImage.src = this.BASE64_NOT_FOUND;
669
+ };
670
+ this._canvasImage.src = params.src;
604
671
  this._ref = new Konva.Image({
605
672
  x: params.position.x,
606
673
  y: params.position.y,
@@ -609,13 +676,6 @@ class KonvaImage {
609
676
  height: (_b = params.height) !== null && _b !== void 0 ? _b : 0,
610
677
  draggable: true
611
678
  });
612
- this._canvasImage.onload = () => {
613
- this._ref.image(this._canvasImage);
614
- if (this._ref.height() === 0) this._ref.height(this._canvasImage.height);
615
- if (this._ref.width() === 0) this._ref.width(this._canvasImage.width);
616
- this._ratio = this._ref.height() === 0 || this._ref.width() === 0 ? 1 : this._ref.height() / this._ref.width();
617
- };
618
- this._canvasImage.src = params.src;
619
679
  this._ref.on("transform", (e => {
620
680
  const attrs = e.target.attrs;
621
681
  if (attrs.rotation !== this._ref.rotation()) this._ref.rotation(attrs.rotation);
@@ -714,7 +774,11 @@ class KonvaCloud {
714
774
  this._ref = ref;
715
775
  return;
716
776
  }
717
- if (!params || !params.position) return;
777
+ if (!params) params = {};
778
+ if (!params.position) params.position = {
779
+ x: 100,
780
+ y: 100
781
+ };
718
782
  const arcRadius = 16;
719
783
  this._ref = new Konva.Shape({
720
784
  x: params.position.x,
@@ -1710,6 +1774,8 @@ class KonvaMarkup {
1710
1774
  src: src,
1711
1775
  width: width,
1712
1776
  height: height,
1777
+ maxWidth: this._konvaStage.width() - position.x,
1778
+ maxHeight: this._konvaStage.height() - position.y,
1713
1779
  id: id
1714
1780
  });
1715
1781
  this.addObject(konvaImage);