@leafer-draw/miniapp 1.0.0-rc.22 → 1.0.0-rc.23

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.
@@ -3,7 +3,7 @@ const Platform = {
3
3
  hitCanvasSize: 100,
4
4
  maxCacheSize: 2560 * 1600,
5
5
  maxPatternSize: 4096 * 2160,
6
- suffix: 'leaf',
6
+ suffix: '',
7
7
  crossOrigin: 'anonymous'
8
8
  }
9
9
  };
@@ -33,24 +33,12 @@ const I$1 = IncrementId;
33
33
  const { round, pow: pow$1, PI: PI$4 } = Math;
34
34
  const MathHelper = {
35
35
  within(value, min, max) {
36
- if (value < min)
36
+ if (min !== undefined && value < min)
37
37
  value = min;
38
- if (value > max)
38
+ if (max !== undefined && value > max)
39
39
  value = max;
40
40
  return value;
41
41
  },
42
- minus(value, isFourNumber) {
43
- if (value instanceof Array) {
44
- if (isFourNumber)
45
- value = MathHelper.fourNumber(value, 0);
46
- for (let i = 0; i < value.length; i++)
47
- value[i] = -value[i];
48
- }
49
- else {
50
- value = -value;
51
- }
52
- return value;
53
- },
54
42
  fourNumber(num, maxValue) {
55
43
  let data;
56
44
  if (num instanceof Array) {
@@ -147,9 +135,11 @@ const MatrixHelper = {
147
135
  t.e += x;
148
136
  t.f += y;
149
137
  },
150
- translateInner(t, x, y) {
138
+ translateInner(t, x, y, isMoveOrigin) {
151
139
  t.e += t.a * x + t.c * y;
152
140
  t.f += t.b * x + t.d * y;
141
+ if (isMoveOrigin)
142
+ t.e -= x, t.f -= y;
153
143
  },
154
144
  scale(t, scaleX, scaleY = scaleX) {
155
145
  t.a *= scaleX;
@@ -216,8 +206,10 @@ const MatrixHelper = {
216
206
  t.e = child.e * a + child.f * c + e;
217
207
  t.f = child.e * b + child.f * d + f;
218
208
  },
219
- multiplyParent(t, parent, to, abcdChanged, childScaleData) {
220
- const { e, f } = t;
209
+ multiplyParent(t, parent, to, abcdChanged, childScaleData, scrollData) {
210
+ let { e, f } = t;
211
+ if (scrollData)
212
+ e += scrollData.scrollX, f += scrollData.scrollY;
221
213
  to || (to = t);
222
214
  if (abcdChanged === undefined)
223
215
  abcdChanged = t.a !== 1 || t.b || t.c || t.d !== 1;
@@ -338,7 +330,7 @@ const MatrixHelper = {
338
330
  t.e = x;
339
331
  t.f = y;
340
332
  if (origin)
341
- M$6.translateInner(t, -origin.x, -origin.y);
333
+ M$6.translateInner(t, -origin.x, -origin.y, true);
342
334
  },
343
335
  getLayout(t, origin, firstSkewY) {
344
336
  const { a, b, c, d, e, f } = t;
@@ -758,7 +750,7 @@ const { float, fourNumber } = MathHelper;
758
750
  const { floor, ceil: ceil$2 } = Math;
759
751
  let right$1, bottom$1, boundsRight, boundsBottom;
760
752
  const point = {};
761
- const toPoint$1 = {};
753
+ const toPoint$2 = {};
762
754
  const BoundsHelper = {
763
755
  tempBounds: {},
764
756
  set(t, x = 0, y = 0, width = 0, height = 0) {
@@ -773,15 +765,17 @@ const BoundsHelper = {
773
765
  t.width = bounds.width;
774
766
  t.height = bounds.height;
775
767
  },
776
- copyAndSpread(t, bounds, spreadX, spreadY) {
777
- if (spreadX instanceof Array) {
778
- const four = fourNumber(spreadX);
779
- B.set(t, bounds.x - four[3], bounds.y - four[0], bounds.width + four[1] + four[3], bounds.height + four[2] + four[0]);
768
+ copyAndSpread(t, bounds, spread, isShrink) {
769
+ if (spread instanceof Array) {
770
+ const four = fourNumber(spread);
771
+ isShrink
772
+ ? B.set(t, bounds.x + four[3], bounds.y + four[0], bounds.width - four[1] - four[3], bounds.height - four[2] - four[0])
773
+ : B.set(t, bounds.x - four[3], bounds.y - four[0], bounds.width + four[1] + four[3], bounds.height + four[2] + four[0]);
780
774
  }
781
775
  else {
782
- if (!spreadY)
783
- spreadY = spreadX;
784
- B.set(t, bounds.x - spreadX, bounds.y - spreadY, bounds.width + spreadX * 2, bounds.height + spreadY * 2);
776
+ if (isShrink)
777
+ spread = -spread;
778
+ B.set(t, bounds.x - spread, bounds.y - spread, bounds.width + spread * 2, bounds.height + spread * 2);
785
779
  }
786
780
  },
787
781
  minX(t) { return t.width > 0 ? t.x : t.x + t.width; },
@@ -858,17 +852,17 @@ const BoundsHelper = {
858
852
  else {
859
853
  point.x = t.x;
860
854
  point.y = t.y;
861
- toOuterPoint$1(matrix, point, toPoint$1);
862
- setPoint$3(tempPointBounds$1, toPoint$1.x, toPoint$1.y);
855
+ toOuterPoint$1(matrix, point, toPoint$2);
856
+ setPoint$3(tempPointBounds$1, toPoint$2.x, toPoint$2.y);
863
857
  point.x = t.x + t.width;
864
- toOuterPoint$1(matrix, point, toPoint$1);
865
- addPoint$3(tempPointBounds$1, toPoint$1.x, toPoint$1.y);
858
+ toOuterPoint$1(matrix, point, toPoint$2);
859
+ addPoint$3(tempPointBounds$1, toPoint$2.x, toPoint$2.y);
866
860
  point.y = t.y + t.height;
867
- toOuterPoint$1(matrix, point, toPoint$1);
868
- addPoint$3(tempPointBounds$1, toPoint$1.x, toPoint$1.y);
861
+ toOuterPoint$1(matrix, point, toPoint$2);
862
+ addPoint$3(tempPointBounds$1, toPoint$2.x, toPoint$2.y);
869
863
  point.x = t.x;
870
- toOuterPoint$1(matrix, point, toPoint$1);
871
- addPoint$3(tempPointBounds$1, toPoint$1.x, toPoint$1.y);
864
+ toOuterPoint$1(matrix, point, toPoint$2);
865
+ addPoint$3(tempPointBounds$1, toPoint$2.x, toPoint$2.y);
872
866
  toBounds$4(tempPointBounds$1, to);
873
867
  }
874
868
  },
@@ -881,13 +875,16 @@ const BoundsHelper = {
881
875
  const scale = Math.min(baseScale, Math.min(t.width / put.width, t.height / put.height));
882
876
  return new Matrix(scale, 0, 0, scale, -put.x * scale, -put.y * scale);
883
877
  },
884
- getSpread(t, spreadX, spreadY) {
878
+ getSpread(t, spread) {
885
879
  const n = {};
886
- B.copyAndSpread(n, t, spreadX, spreadY);
880
+ B.copyAndSpread(n, t, spread);
887
881
  return n;
888
882
  },
889
- spread(t, spreadX, spreadY = spreadX) {
890
- B.copyAndSpread(t, t, spreadX, spreadY);
883
+ spread(t, spread) {
884
+ B.copyAndSpread(t, t, spread);
885
+ },
886
+ shrink(t, shrink) {
887
+ B.copyAndSpread(t, t, shrink, true);
891
888
  },
892
889
  ceil(t) {
893
890
  const { x, y } = t;
@@ -1067,12 +1064,12 @@ class Bounds {
1067
1064
  getFitMatrix(put, baseScale) {
1068
1065
  return BoundsHelper.getFitMatrix(this, put, baseScale);
1069
1066
  }
1070
- spread(fourNumber, spreadY) {
1071
- BoundsHelper.spread(this, fourNumber, spreadY);
1067
+ spread(fourNumber) {
1068
+ BoundsHelper.spread(this, fourNumber);
1072
1069
  return this;
1073
1070
  }
1074
1071
  shrink(fourNumber) {
1075
- BoundsHelper.spread(this, MathHelper.minus(fourNumber, true));
1072
+ BoundsHelper.shrink(this, fourNumber);
1076
1073
  return this;
1077
1074
  }
1078
1075
  ceil() {
@@ -1189,6 +1186,10 @@ var Direction9;
1189
1186
  Direction9[Direction9["bottomLeft"] = 6] = "bottomLeft";
1190
1187
  Direction9[Direction9["left"] = 7] = "left";
1191
1188
  Direction9[Direction9["center"] = 8] = "center";
1189
+ Direction9[Direction9["top-left"] = 0] = "top-left";
1190
+ Direction9[Direction9["top-right"] = 2] = "top-right";
1191
+ Direction9[Direction9["bottom-right"] = 4] = "bottom-right";
1192
+ Direction9[Direction9["bottom-left"] = 6] = "bottom-left";
1192
1193
  })(Direction9 || (Direction9 = {}));
1193
1194
 
1194
1195
  const directionData = [
@@ -1202,6 +1203,7 @@ const directionData = [
1202
1203
  { x: 0, y: 0.5 },
1203
1204
  { x: 0.5, y: 0.5 }
1204
1205
  ];
1206
+ directionData.forEach(item => item.type = 'percent');
1205
1207
  const AroundHelper = {
1206
1208
  directionData,
1207
1209
  tempPoint: {},
@@ -1209,15 +1211,19 @@ const AroundHelper = {
1209
1211
  toPoint(around, bounds, to, onlySize, pointBounds) {
1210
1212
  to || (to = {});
1211
1213
  const point = get$5(around);
1212
- to.x = point.x * bounds.width;
1213
- to.y = point.y * bounds.height;
1214
- if (pointBounds) {
1215
- to.x -= pointBounds.x;
1216
- to.y -= pointBounds.y;
1217
- if (point.x)
1218
- to.x -= (point.x === 1) ? pointBounds.width : (point.x === 0.5 ? point.x * pointBounds.width : 0);
1219
- if (point.y)
1220
- to.y -= (point.y === 1) ? pointBounds.height : (point.y === 0.5 ? point.y * pointBounds.height : 0);
1214
+ to.x = point.x;
1215
+ to.y = point.y;
1216
+ if (point.type === 'percent') {
1217
+ to.x *= bounds.width;
1218
+ to.y *= bounds.height;
1219
+ if (pointBounds) {
1220
+ to.x -= pointBounds.x;
1221
+ to.y -= pointBounds.y;
1222
+ if (point.x)
1223
+ to.x -= (point.x === 1) ? pointBounds.width : (point.x === 0.5 ? point.x * pointBounds.width : 0);
1224
+ if (point.y)
1225
+ to.y -= (point.y === 1) ? pointBounds.height : (point.y === 0.5 ? point.y * pointBounds.height : 0);
1226
+ }
1221
1227
  }
1222
1228
  if (!onlySize) {
1223
1229
  to.x += bounds.x;
@@ -1229,6 +1235,13 @@ function get$5(around) {
1229
1235
  return typeof around === 'string' ? directionData[Direction9[around]] : around;
1230
1236
  }
1231
1237
 
1238
+ const { toPoint: toPoint$1 } = AroundHelper;
1239
+ const AlignHelper = {
1240
+ toPoint(align, contentBounds, bounds, to, onlySize) {
1241
+ toPoint$1(align, bounds, to, onlySize, contentBounds);
1242
+ }
1243
+ };
1244
+
1232
1245
  const StringNumberMap = {
1233
1246
  '0': 1,
1234
1247
  '1': 1,
@@ -1461,13 +1474,19 @@ const DataHelper = {
1461
1474
  },
1462
1475
  clone(data) {
1463
1476
  return JSON.parse(JSON.stringify(data));
1477
+ },
1478
+ toMap(list) {
1479
+ const map = {};
1480
+ for (let i = 0, len = list.length; i < len; i++)
1481
+ map[list[i]] = true;
1482
+ return map;
1464
1483
  }
1465
1484
  };
1466
1485
  const { assign } = DataHelper;
1467
1486
 
1468
1487
  class LeafData {
1469
1488
  get __blendMode() {
1470
- if (this.eraser)
1489
+ if (this.eraser && this.eraser !== 'path')
1471
1490
  return 'destination-out';
1472
1491
  const { blendMode } = this;
1473
1492
  return blendMode === 'pass-through' ? null : blendMode;
@@ -2097,7 +2116,7 @@ class LeaferCanvasBase extends Canvas$1 {
2097
2116
  }
2098
2117
  clear() {
2099
2118
  const { pixelRatio } = this;
2100
- this.clearRect(0, 0, this.width * pixelRatio, this.height * pixelRatio);
2119
+ this.clearRect(0, 0, this.width * pixelRatio + 2, this.height * pixelRatio + 2);
2101
2120
  }
2102
2121
  isSameSize(size) {
2103
2122
  return this.width === size.width && this.height === size.height && this.pixelRatio === size.pixelRatio;
@@ -3753,6 +3772,8 @@ function maskType(defaultValue) {
3753
3772
  this.__setAttr(key, value);
3754
3773
  this.__layout.boxChanged || this.__layout.boxChange();
3755
3774
  this.waitParent(() => { this.parent.__updateMask(value); });
3775
+ if (typeof value === 'string')
3776
+ this.maskType = value;
3756
3777
  }
3757
3778
  }));
3758
3779
  }
@@ -4182,11 +4203,19 @@ const WaitHelper = {
4182
4203
 
4183
4204
  const { getRelativeWorld: getRelativeWorld$1 } = LeafHelper;
4184
4205
  const { toOuterOf: toOuterOf$2, getPoints, copy: copy$5 } = BoundsHelper;
4206
+ const localContent = '_localContentBounds';
4207
+ const worldContent = '_worldContentBounds', worldBox = '_worldBoxBounds', worldStroke = '_worldStrokeBounds';
4185
4208
  class LeafLayout {
4209
+ get contentBounds() { return this._contentBounds || this.boxBounds; }
4210
+ set contentBounds(bounds) { this._contentBounds = bounds; }
4186
4211
  get strokeBounds() { return this._strokeBounds || this.boxBounds; }
4187
4212
  get renderBounds() { return this._renderBounds || this.boxBounds; }
4213
+ get localContentBounds() { toOuterOf$2(this.contentBounds, this.leaf.__localMatrix, this[localContent] || (this[localContent] = {})); return this[localContent]; }
4188
4214
  get localStrokeBounds() { return this._localStrokeBounds || this; }
4189
4215
  get localRenderBounds() { return this._localRenderBounds || this; }
4216
+ get worldContentBounds() { toOuterOf$2(this.contentBounds, this.leaf.__world, this[worldContent] || (this[worldContent] = {})); return this[worldContent]; }
4217
+ get worldBoxBounds() { toOuterOf$2(this.boxBounds, this.leaf.__world, this[worldBox] || (this[worldBox] = {})); return this[worldBox]; }
4218
+ get worldStrokeBounds() { toOuterOf$2(this.strokeBounds, this.leaf.__world, this[worldStroke] || (this[worldStroke] = {})); return this[worldStroke]; }
4190
4219
  get a() { return 1; }
4191
4220
  get b() { return 0; }
4192
4221
  get c() { return 0; }
@@ -4269,7 +4298,6 @@ class LeafLayout {
4269
4298
  case 'content':
4270
4299
  if (this.contentBounds)
4271
4300
  return this.contentBounds;
4272
- case 'margin':
4273
4301
  case 'box':
4274
4302
  return this.boxBounds;
4275
4303
  case 'stroke':
@@ -4282,8 +4310,9 @@ class LeafLayout {
4282
4310
  return this.localRenderBounds;
4283
4311
  case 'stroke':
4284
4312
  return this.localStrokeBounds;
4285
- case 'margin':
4286
4313
  case 'content':
4314
+ if (this.contentBounds)
4315
+ return this.localContentBounds;
4287
4316
  case 'box':
4288
4317
  return this.leaf.__localBoxBounds;
4289
4318
  }
@@ -4292,15 +4321,13 @@ class LeafLayout {
4292
4321
  switch (type) {
4293
4322
  case 'render':
4294
4323
  return this.leaf.__world;
4324
+ case 'stroke':
4325
+ return this.worldStrokeBounds;
4295
4326
  case 'content':
4296
4327
  if (this.contentBounds)
4297
- return this.getWorldContentBounds();
4298
- case 'margin':
4328
+ return this.worldContentBounds;
4299
4329
  case 'box':
4300
- return this.getWorldBoxBounds();
4301
- case 'margin':
4302
- case 'stroke':
4303
- return this.getWorldStrokeBounds();
4330
+ return this.worldBoxBounds;
4304
4331
  }
4305
4332
  }
4306
4333
  getLayoutBounds(type, relative = 'world', unscale) {
@@ -4363,20 +4390,24 @@ class LeafLayout {
4363
4390
  points.forEach(point => leaf.innerToWorld(point, null, false, relativeLeaf));
4364
4391
  return points;
4365
4392
  }
4366
- getWorldContentBounds() {
4367
- this._worldContentBounds || (this._worldContentBounds = {});
4368
- toOuterOf$2(this.contentBounds, this.leaf.__world, this._worldContentBounds);
4369
- return this._worldContentBounds;
4393
+ shrinkContent() {
4394
+ const { x, y, width, height } = this.boxBounds;
4395
+ this._contentBounds = { x, y, width, height };
4370
4396
  }
4371
- getWorldBoxBounds() {
4372
- this._worldBoxBounds || (this._worldBoxBounds = {});
4373
- toOuterOf$2(this.boxBounds, this.leaf.__world, this._worldBoxBounds);
4374
- return this._worldBoxBounds;
4397
+ spreadStroke() {
4398
+ const { x, y, width, height } = this.strokeBounds;
4399
+ this._strokeBounds = { x, y, width, height };
4400
+ this._localStrokeBounds = { x, y, width, height };
4401
+ if (!this.renderSpread)
4402
+ this.spreadRenderCancel();
4403
+ }
4404
+ spreadRender() {
4405
+ const { x, y, width, height } = this.renderBounds;
4406
+ this._renderBounds = { x, y, width, height };
4407
+ this._localRenderBounds = { x, y, width, height };
4375
4408
  }
4376
- getWorldStrokeBounds() {
4377
- this._worldStrokeBounds || (this._worldStrokeBounds = {});
4378
- toOuterOf$2(this.strokeBounds, this.leaf.__world, this._worldStrokeBounds);
4379
- return this._worldStrokeBounds;
4409
+ shrinkContentCancel() {
4410
+ this._contentBounds = undefined;
4380
4411
  }
4381
4412
  spreadStrokeCancel() {
4382
4413
  const same = this.renderBounds === this.strokeBounds;
@@ -4389,18 +4420,6 @@ class LeafLayout {
4389
4420
  this._renderBounds = this._strokeBounds;
4390
4421
  this._localRenderBounds = this._localStrokeBounds;
4391
4422
  }
4392
- spreadStroke() {
4393
- const { x, y, width, height } = this.strokeBounds;
4394
- this._strokeBounds = { x, y, width, height };
4395
- this._localStrokeBounds = { x, y, width, height };
4396
- if (!this.renderSpread)
4397
- this.spreadRenderCancel();
4398
- }
4399
- spreadRender() {
4400
- const { x, y, width, height } = this.renderBounds;
4401
- this._renderBounds = { x, y, width, height };
4402
- this._localRenderBounds = { x, y, width, height };
4403
- }
4404
4423
  boxChange() {
4405
4424
  this.boxChanged = true;
4406
4425
  this.localBoxChanged || this.localBoxChange();
@@ -4487,24 +4506,40 @@ const LeafEventer = {
4487
4506
  });
4488
4507
  },
4489
4508
  off(type, listener, options) {
4490
- let capture;
4491
- if (options)
4492
- capture = typeof options === 'boolean' ? options : options.capture;
4493
- let events, index;
4494
- const map = __getListenerMap(this, capture);
4495
- const typeList = typeof type === 'string' ? type.split(' ') : type;
4496
- typeList.forEach(type => {
4497
- if (type) {
4498
- events = map[type];
4499
- if (events) {
4500
- index = events.findIndex(item => item.listener === listener);
4501
- if (index > -1)
4502
- events.splice(index, 1);
4503
- if (!events.length)
4504
- delete map[type];
4505
- }
4509
+ if (type) {
4510
+ const typeList = typeof type === 'string' ? type.split(' ') : type;
4511
+ if (listener) {
4512
+ let capture;
4513
+ if (options)
4514
+ capture = typeof options === 'boolean' ? options : options.capture;
4515
+ let events, index;
4516
+ const map = __getListenerMap(this, capture);
4517
+ typeList.forEach(type => {
4518
+ if (type) {
4519
+ events = map[type];
4520
+ if (events) {
4521
+ index = events.findIndex(item => item.listener === listener);
4522
+ if (index > -1)
4523
+ events.splice(index, 1);
4524
+ if (!events.length)
4525
+ delete map[type];
4526
+ }
4527
+ }
4528
+ });
4506
4529
  }
4507
- });
4530
+ else {
4531
+ const { __bubbleMap: b, __captureMap: c } = this;
4532
+ typeList.forEach(type => {
4533
+ if (b)
4534
+ delete b[type];
4535
+ if (c)
4536
+ delete c[type];
4537
+ });
4538
+ }
4539
+ }
4540
+ else {
4541
+ this.__bubbleMap = this.__captureMap = undefined;
4542
+ }
4508
4543
  },
4509
4544
  on_(type, listener, bind, options) {
4510
4545
  if (bind)
@@ -4771,7 +4806,7 @@ const { setLayout, multiplyParent: multiplyParent$1, translateInner, defaultWorl
4771
4806
  const { toPoint, tempPoint: tempPoint$1 } = AroundHelper;
4772
4807
  const LeafMatrix = {
4773
4808
  __updateWorldMatrix() {
4774
- multiplyParent$1(this.__local || this.__layout, this.parent ? this.parent.__world : defaultWorld, this.__world, !!this.__layout.affectScaleOrRotation, this.__);
4809
+ multiplyParent$1(this.__local || this.__layout, this.parent ? this.parent.__world : defaultWorld, this.__world, !!this.__layout.affectScaleOrRotation, this.__, this.parent && this.parent.__);
4775
4810
  },
4776
4811
  __updateLocalMatrix() {
4777
4812
  if (this.__local) {
@@ -4782,11 +4817,11 @@ const LeafMatrix = {
4782
4817
  layout.scaleChanged = layout.rotationChanged = false;
4783
4818
  }
4784
4819
  }
4785
- local.e = data.x;
4786
- local.f = data.y;
4787
- if (data.around) {
4788
- toPoint(data.around, layout.boxBounds, tempPoint$1);
4789
- translateInner(local, -tempPoint$1.x, -tempPoint$1.y);
4820
+ local.e = data.x + data.offsetX;
4821
+ local.f = data.y + data.offsetY;
4822
+ if (data.around || data.origin) {
4823
+ toPoint(data.around || data.origin, layout.boxBounds, tempPoint$1);
4824
+ translateInner(local, -tempPoint$1.x, -tempPoint$1.y, data.origin);
4790
4825
  }
4791
4826
  }
4792
4827
  this.__layout.matrixChanged = false;
@@ -4892,6 +4927,8 @@ const LeafBounds = {
4892
4927
  if (this.isBranch) {
4893
4928
  if (this.leafer)
4894
4929
  this.leafer.layouter.addExtra(this);
4930
+ if (this.__.flow)
4931
+ this.__updateFlowLayout();
4895
4932
  if (hasParentAutoLayout(this)) {
4896
4933
  updateMatrix$1(this);
4897
4934
  }
@@ -4924,6 +4961,8 @@ const LeafRender = {
4924
4961
  canvas.setWorld(this.__nowWorld = this.__getNowWorld(options));
4925
4962
  canvas.opacity = this.__.opacity;
4926
4963
  if (this.__.__single) {
4964
+ if (this.__.eraser === 'path')
4965
+ return this.__renderEraser(canvas, options);
4927
4966
  const tempCanvas = canvas.getSameCanvas(true, true);
4928
4967
  this.__draw(tempCanvas, options);
4929
4968
  if (this.__worldFlipped) {
@@ -4966,6 +5005,8 @@ const BranchRender = {
4966
5005
  __render(canvas, options) {
4967
5006
  if (this.__worldOpacity) {
4968
5007
  if (this.__.__single) {
5008
+ if (this.__.eraser === 'path')
5009
+ return this.__renderEraser(canvas, options);
4969
5010
  const tempCanvas = canvas.getSameCanvas(false, true);
4970
5011
  this.__renderBranch(tempCanvas, options);
4971
5012
  const nowWorld = this.__getNowWorld(options);
@@ -5105,7 +5146,9 @@ let Leaf = class Leaf {
5105
5146
  setProxyAttr(_attrName, _newValue) { }
5106
5147
  getProxyAttr(_attrName) { return undefined; }
5107
5148
  find(_condition, _options) { return undefined; }
5149
+ findTag(_tag) { return undefined; }
5108
5150
  findOne(_condition, _options) { return undefined; }
5151
+ findId(_id) { return undefined; }
5109
5152
  focus(_value) { }
5110
5153
  forceUpdate(attrName) {
5111
5154
  if (attrName === undefined)
@@ -5127,9 +5170,11 @@ let Leaf = class Leaf {
5127
5170
  __updateLocalStrokeBounds() { }
5128
5171
  __updateLocalRenderBounds() { }
5129
5172
  __updateBoxBounds() { }
5173
+ __updateContentBounds() { }
5130
5174
  __updateStrokeBounds() { }
5131
5175
  __updateRenderBounds() { }
5132
5176
  __updateAutoLayout() { }
5177
+ __updateFlowLayout() { }
5133
5178
  __updateNaturalSize() { }
5134
5179
  __updateStrokeSpread() { return 0; }
5135
5180
  __updateRenderSpread() { return 0; }
@@ -5137,6 +5182,13 @@ let Leaf = class Leaf {
5137
5182
  __updateEraser(value) {
5138
5183
  this.__hasEraser = value ? true : this.children.some(item => item.__.eraser);
5139
5184
  }
5185
+ __renderEraser(canvas, options) {
5186
+ canvas.save();
5187
+ this.__clip(canvas, options);
5188
+ const { renderBounds: r } = this.__layout;
5189
+ canvas.clearRect(r.x, r.y, r.width, r.height);
5190
+ canvas.restore();
5191
+ }
5140
5192
  __updateMask(value) {
5141
5193
  this.__hasMask = value ? true : this.children.some(item => item.__.mask);
5142
5194
  }
@@ -5317,8 +5369,8 @@ let Leaf = class Leaf {
5317
5369
  emit(_type, _event, _capture) { }
5318
5370
  emitEvent(_event, _capture) { }
5319
5371
  hasEvent(_type, _capture) { return false; }
5320
- static changeAttr(attrName, defaultValue) {
5321
- defineDataProcessor(this.prototype, attrName, defaultValue);
5372
+ static changeAttr(attrName, defaultValue, fn) {
5373
+ fn ? this.addAttr(attrName, defaultValue, fn) : defineDataProcessor(this.prototype, attrName, defaultValue);
5322
5374
  }
5323
5375
  static addAttr(attrName, defaultValue, fn) {
5324
5376
  if (!fn)
@@ -6364,8 +6416,11 @@ class Renderer {
6364
6416
  if (!bounds.includes(this.target.__world) || this.needFill || !e.samePixelRatio) {
6365
6417
  this.addBlock(this.canvas.bounds);
6366
6418
  this.target.forceUpdate('surface');
6419
+ return;
6367
6420
  }
6368
6421
  }
6422
+ this.addBlock(new Bounds(0, 0, 1, 1));
6423
+ this.changed = true;
6369
6424
  }
6370
6425
  __onLayoutEnd(event) {
6371
6426
  if (event.data)
@@ -6615,7 +6670,7 @@ class UIData extends LeafData {
6615
6670
  const UnitConvert = {
6616
6671
  number(value, percentRefer) {
6617
6672
  if (typeof value === 'object')
6618
- return value.type === 'percent' ? value.value / 100 * percentRefer : value.value;
6673
+ return value.type === 'percent' ? (value.value > 49 ? value.value / 100 : value.value) * percentRefer : value.value;
6619
6674
  return value;
6620
6675
  }
6621
6676
  };
@@ -6896,7 +6951,9 @@ let UI = UI_1 = class UI extends Leaf {
6896
6951
  }
6897
6952
  createProxyData() { return undefined; }
6898
6953
  find(_condition, _options) { return undefined; }
6954
+ findTag(tag) { return this.find({ tag }); }
6899
6955
  findOne(_condition, _options) { return undefined; }
6956
+ findId(id) { return this.findOne({ id }); }
6900
6957
  getPath(curve, pathForRender) {
6901
6958
  this.__layout.update();
6902
6959
  let path = pathForRender ? this.__.__pathForRender : this.__.path;
@@ -7047,9 +7104,75 @@ __decorate([
7047
7104
  __decorate([
7048
7105
  rotationType(0, true)
7049
7106
  ], UI.prototype, "skewY", void 0);
7107
+ __decorate([
7108
+ positionType(0, true)
7109
+ ], UI.prototype, "offsetX", void 0);
7110
+ __decorate([
7111
+ positionType(0, true)
7112
+ ], UI.prototype, "offsetY", void 0);
7113
+ __decorate([
7114
+ positionType(0, true)
7115
+ ], UI.prototype, "scrollX", void 0);
7116
+ __decorate([
7117
+ positionType(0, true)
7118
+ ], UI.prototype, "scrollY", void 0);
7119
+ __decorate([
7120
+ autoLayoutType()
7121
+ ], UI.prototype, "origin", void 0);
7050
7122
  __decorate([
7051
7123
  autoLayoutType()
7052
7124
  ], UI.prototype, "around", void 0);
7125
+ __decorate([
7126
+ dataType(false)
7127
+ ], UI.prototype, "lazy", void 0);
7128
+ __decorate([
7129
+ naturalBoundsType(1)
7130
+ ], UI.prototype, "pixelRatio", void 0);
7131
+ __decorate([
7132
+ pathInputType()
7133
+ ], UI.prototype, "path", void 0);
7134
+ __decorate([
7135
+ pathType()
7136
+ ], UI.prototype, "windingRule", void 0);
7137
+ __decorate([
7138
+ pathType(true)
7139
+ ], UI.prototype, "closed", void 0);
7140
+ __decorate([
7141
+ autoLayoutType(false)
7142
+ ], UI.prototype, "flow", void 0);
7143
+ __decorate([
7144
+ boundsType(0)
7145
+ ], UI.prototype, "padding", void 0);
7146
+ __decorate([
7147
+ boundsType(0)
7148
+ ], UI.prototype, "gap", void 0);
7149
+ __decorate([
7150
+ boundsType('top-left')
7151
+ ], UI.prototype, "align", void 0);
7152
+ __decorate([
7153
+ boundsType(false)
7154
+ ], UI.prototype, "wrap", void 0);
7155
+ __decorate([
7156
+ boundsType('box')
7157
+ ], UI.prototype, "itemBox", void 0);
7158
+ __decorate([
7159
+ boundsType(true)
7160
+ ], UI.prototype, "inFlow", void 0);
7161
+ __decorate([
7162
+ boundsType()
7163
+ ], UI.prototype, "autoWidth", void 0);
7164
+ __decorate([
7165
+ boundsType()
7166
+ ], UI.prototype, "autoHeight", void 0);
7167
+ __decorate([
7168
+ boundsType()
7169
+ ], UI.prototype, "autoBox", void 0);
7170
+ __decorate([
7171
+ boundsType()
7172
+ ], UI.prototype, "widthRange", void 0);
7173
+ __decorate([
7174
+ boundsType()
7175
+ ], UI.prototype, "heightRange", void 0);
7053
7176
  __decorate([
7054
7177
  dataType(false)
7055
7178
  ], UI.prototype, "draggable", void 0);
@@ -7059,9 +7182,6 @@ __decorate([
7059
7182
  __decorate([
7060
7183
  dataType(false)
7061
7184
  ], UI.prototype, "editable", void 0);
7062
- __decorate([
7063
- dataType('size')
7064
- ], UI.prototype, "editSize", void 0);
7065
7185
  __decorate([
7066
7186
  hitType(true)
7067
7187
  ], UI.prototype, "hittable", void 0);
@@ -7116,21 +7236,6 @@ __decorate([
7116
7236
  __decorate([
7117
7237
  strokeType(10)
7118
7238
  ], UI.prototype, "miterLimit", void 0);
7119
- __decorate([
7120
- dataType(false)
7121
- ], UI.prototype, "lazy", void 0);
7122
- __decorate([
7123
- naturalBoundsType(1)
7124
- ], UI.prototype, "pixelRatio", void 0);
7125
- __decorate([
7126
- pathInputType()
7127
- ], UI.prototype, "path", void 0);
7128
- __decorate([
7129
- pathType()
7130
- ], UI.prototype, "windingRule", void 0);
7131
- __decorate([
7132
- pathType(true)
7133
- ], UI.prototype, "closed", void 0);
7134
7239
  __decorate([
7135
7240
  arrowType('none')
7136
7241
  ], UI.prototype, "startArrow", void 0);
@@ -7364,9 +7469,6 @@ let Leafer = Leafer_1 = class Leafer extends Group {
7364
7469
  const data = DataHelper.copyAttrs({}, size, canvasSizeAttrs);
7365
7470
  Object.keys(data).forEach(key => this[key] = data[key]);
7366
7471
  }
7367
- forceFullRender() {
7368
- this.forceRender();
7369
- }
7370
7472
  forceRender(bounds) {
7371
7473
  this.renderer.addBlock(bounds ? new Bounds(bounds) : this.canvas.bounds);
7372
7474
  if (this.viewReady)
@@ -7444,7 +7546,7 @@ let Leafer = Leafer_1 = class Leafer extends Group {
7444
7546
  this.canvas.backgroundColor = newValue;
7445
7547
  }
7446
7548
  else {
7447
- this.forceFullRender();
7549
+ this.forceRender();
7448
7550
  }
7449
7551
  }
7450
7552
  __onCreated() {
@@ -7655,6 +7757,8 @@ let Box = class Box extends Group {
7655
7757
  else {
7656
7758
  this.__updateRectBoxBounds();
7657
7759
  }
7760
+ if (data.flow)
7761
+ this.__updateContentBounds();
7658
7762
  }
7659
7763
  __updateStrokeBounds() { }
7660
7764
  __updateRenderBounds() {
@@ -8064,7 +8168,7 @@ Canvas = __decorate([
8064
8168
  registerUI()
8065
8169
  ], Canvas);
8066
8170
 
8067
- const { copyAndSpread, includes, spread, setList } = BoundsHelper;
8171
+ const { copyAndSpread, includes, isSame: isSame$1, spread, setList } = BoundsHelper;
8068
8172
  let Text = class Text extends UI {
8069
8173
  get __tag() { return 'Text'; }
8070
8174
  get editInner() { return 'TextEditor'; }
@@ -8137,7 +8241,7 @@ let Text = class Text extends UI {
8137
8241
  if (italic)
8138
8242
  b.width += fontSize * 0.16;
8139
8243
  const contentBounds = includes(b, bounds) ? b : bounds;
8140
- if (contentBounds !== layout.contentBounds) {
8244
+ if (!isSame$1(contentBounds, layout.contentBounds)) {
8141
8245
  layout.contentBounds = contentBounds;
8142
8246
  layout.renderChanged = true;
8143
8247
  setList(data.__textBoxBounds = {}, [b, bounds]);
@@ -8165,9 +8269,6 @@ __decorate([
8165
8269
  __decorate([
8166
8270
  boundsType(0)
8167
8271
  ], Text.prototype, "height", void 0);
8168
- __decorate([
8169
- boundsType(0)
8170
- ], Text.prototype, "padding", void 0);
8171
8272
  __decorate([
8172
8273
  surfaceType('#000000')
8173
8274
  ], Text.prototype, "fill", void 0);
@@ -8296,7 +8397,7 @@ function penPathType() {
8296
8397
  };
8297
8398
  }
8298
8399
 
8299
- const version = "1.0.0-rc.21";
8400
+ const version = "1.0.0-rc.23";
8300
8401
 
8301
8402
  function fillText(ui, canvas) {
8302
8403
  let row;
@@ -8517,7 +8618,7 @@ function shape(ui, current, options) {
8517
8618
  }
8518
8619
  else {
8519
8620
  const { renderShapeSpread: spread } = ui.__layout;
8520
- const worldClipBounds = getIntersectData(spread ? getSpread(current.bounds, spread * scaleX, spread * scaleY) : current.bounds, nowWorld);
8621
+ const worldClipBounds = getIntersectData(spread ? getSpread(current.bounds, scaleX === scaleY ? spread * scaleX : [spread * scaleY, spread * scaleX]) : current.bounds, nowWorld);
8521
8622
  fitMatrix = current.bounds.getFitMatrix(worldClipBounds);
8522
8623
  let { a: fitScaleX, d: fitScaleY } = fitMatrix;
8523
8624
  if (fitMatrix.a < 1) {
@@ -8617,10 +8718,10 @@ function clipMode(data, box, x, y, scaleX, scaleY, rotation) {
8617
8718
  rotate(transform, rotation);
8618
8719
  data.transform = transform;
8619
8720
  }
8620
- function repeatMode(data, box, width, height, x, y, scaleX, scaleY, rotation, around) {
8721
+ function repeatMode(data, box, width, height, x, y, scaleX, scaleY, rotation, align) {
8621
8722
  const transform = get$4();
8622
8723
  if (rotation) {
8623
- if (around === 'center') {
8724
+ if (align === 'center') {
8624
8725
  rotateOfOuter$2(transform, { x: width / 2, y: height / 2 }, rotation);
8625
8726
  }
8626
8727
  else {
@@ -8653,12 +8754,12 @@ function createData(leafPaint, image, paint, box) {
8653
8754
  let { width, height } = image;
8654
8755
  if (paint.padding)
8655
8756
  box = tempBox.set(box).shrink(paint.padding);
8656
- const { opacity, mode, around, offset, scale, size, rotation, blendMode, repeat } = paint;
8757
+ const { opacity, mode, align, offset, scale, size, rotation, blendMode, repeat } = paint;
8657
8758
  const sameBox = box.width === width && box.height === height;
8658
8759
  if (blendMode)
8659
8760
  leafPaint.blendMode = blendMode;
8660
8761
  const data = leafPaint.data = { mode };
8661
- const swapSize = around !== 'center' && (rotation || 0) % 180 === 90;
8762
+ const swapSize = align !== 'center' && (rotation || 0) % 180 === 90;
8662
8763
  const swapWidth = swapSize ? height : width, swapHeight = swapSize ? width : height;
8663
8764
  let x = 0, y = 0, scaleX, scaleY;
8664
8765
  if (!mode || mode === 'cover' || mode === 'fit') {
@@ -8676,11 +8777,11 @@ function createData(leafPaint, image, paint, box) {
8676
8777
  scaleX = typeof scale === 'number' ? scale : scale.x;
8677
8778
  scaleY = typeof scale === 'number' ? scale : scale.y;
8678
8779
  }
8679
- if (around) {
8780
+ if (align) {
8680
8781
  const imageBounds = { x, y, width: swapWidth, height: swapHeight };
8681
8782
  if (scaleX)
8682
8783
  imageBounds.width *= scaleX, imageBounds.height *= scaleY;
8683
- AroundHelper.toPoint(around, box, tempPoint, true, imageBounds);
8784
+ AlignHelper.toPoint(align, imageBounds, box, tempPoint, true);
8684
8785
  x += tempPoint.x, y += tempPoint.y;
8685
8786
  }
8686
8787
  if (offset)
@@ -8697,7 +8798,7 @@ function createData(leafPaint, image, paint, box) {
8697
8798
  break;
8698
8799
  case 'repeat':
8699
8800
  if (!sameBox || scaleX || rotation)
8700
- repeatMode(data, box, width, height, x, y, scaleX, scaleY, rotation, around);
8801
+ repeatMode(data, box, width, height, x, y, scaleX, scaleY, rotation, align);
8701
8802
  if (!repeat)
8702
8803
  data.repeat = 'repeat';
8703
8804
  break;
@@ -9614,11 +9715,13 @@ function clipText(drawData, style) {
9614
9715
  const { rows, overflow } = drawData;
9615
9716
  let { textOverflow } = style;
9616
9717
  rows.splice(overflow);
9617
- if (textOverflow !== 'hide') {
9618
- if (textOverflow === 'ellipsis')
9718
+ if (textOverflow && textOverflow !== 'show') {
9719
+ if (textOverflow === 'hide')
9720
+ textOverflow = '';
9721
+ else if (textOverflow === 'ellipsis')
9619
9722
  textOverflow = '...';
9620
9723
  let char, charRight;
9621
- const ellipsisWidth = Platform.canvas.measureText(textOverflow).width;
9724
+ const ellipsisWidth = textOverflow ? Platform.canvas.measureText(textOverflow).width : 0;
9622
9725
  const right = style.x + style.width - ellipsisWidth;
9623
9726
  const list = style.textWrap === 'none' ? rows : [rows[overflow - 1]];
9624
9727
  list.forEach(row => {
@@ -9786,8 +9889,12 @@ const ExportModule = {
9786
9889
  let renderBounds, trimBounds, scaleX = 1, scaleY = 1;
9787
9890
  const { worldTransform, isLeafer, isFrame } = leaf;
9788
9891
  const { slice, trim, onCanvas } = options;
9789
- const scale = options.scale || 1;
9790
- const pixelRatio = options.pixelRatio || 1;
9892
+ let scale = options.scale || 1;
9893
+ let pixelRatio = options.pixelRatio || 1;
9894
+ if (leaf.isApp) {
9895
+ scale *= pixelRatio;
9896
+ pixelRatio = leaf.app.pixelRatio;
9897
+ }
9791
9898
  const screenshot = options.screenshot || leaf.isApp;
9792
9899
  const fill = (isLeafer && screenshot) ? (options.fill === undefined ? leaf.fill : options.fill) : options.fill;
9793
9900
  const needFill = FileHelper.isOpaqueImage(filename) || fill, matrix = new Matrix();
@@ -9920,4 +10027,4 @@ try {
9920
10027
  }
9921
10028
  catch (_a) { }
9922
10029
 
9923
- export { AnimateEvent, Answer, AroundHelper, AutoBounds, BezierHelper, Bounds, BoundsHelper, Box, BoxData, Branch, BranchHelper, BranchRender, Canvas, CanvasData, CanvasManager, ChildEvent, ColorConvert, Creator, DataHelper, Debug, Direction4, Direction9, Effect, Ellipse, EllipseData, EllipseHelper, Event, EventCreator, Export, FileHelper, Frame, FrameData, Group, GroupData, Image, ImageData, ImageEvent, ImageManager, IncrementId, LayoutEvent, Layouter, Leaf, LeafBounds, LeafBoundsHelper, LeafData, LeafDataProxy, LeafEventer, LeafHelper, LeafLayout, LeafLevelList, LeafList, LeafMatrix, LeafRender, Leafer, LeaferCanvas, LeaferCanvasBase, LeaferData, LeaferEvent, LeaferImage, Line, LineData, MathHelper, Matrix, MatrixHelper, NeedConvertToCanvasCommandMap, OneRadian, PI2, PI_2, Paint, PaintGradient, PaintImage, Path, PathArrow, PathBounds, PathCommandDataHelper, PathCommandMap, PathConvert, PathCorner, PathCreator, PathData, PathDrawer, PathHelper, PathNumberCommandLengthMap, PathNumberCommandMap, Pen, PenData, Platform, Point, PointHelper, Polygon, PolygonData, PropertyEvent, Rect, RectData, RectHelper, RectRender, RenderEvent, Renderer, ResizeEvent, Run, Star, StarData, State, StringNumberMap, TaskItem, TaskProcessor, Text, TextConvert, TextData, TwoPointBoundsHelper, UI, UIBounds, UICreator, UIData, UIRender, UnitConvert, WaitHelper, WatchEvent, Watcher, affectRenderBoundsType, affectStrokeBoundsType, arrowType, attr, autoLayoutType, boundsType, canvasPatch, canvasSizeAttrs, cursorType, dataProcessor, dataType, decorateLeafAttr, defineDataProcessor, defineKey, defineLeafAttr, doBoundsType, doStrokeType, effectType, emptyData, eraserType, getBoundsData, getDescriptor, getMatrixData, getPointData, hitType, layoutProcessor, maskType, naturalBoundsType, opacityType, pathInputType, pathType, pen, positionType, registerUI, registerUIEvent, resizeType, rewrite, rewriteAble, rotationType, scaleType, sortType, stateType, strokeType, surfaceType, tempBounds$1 as tempBounds, tempMatrix, tempPoint$3 as tempPoint, useCanvas, useModule, version, zoomLayerType };
10030
+ export { AlignHelper, AnimateEvent, Answer, AroundHelper, AutoBounds, BezierHelper, Bounds, BoundsHelper, Box, BoxData, Branch, BranchHelper, BranchRender, Canvas, CanvasData, CanvasManager, ChildEvent, ColorConvert, Creator, DataHelper, Debug, Direction4, Direction9, Effect, Ellipse, EllipseData, EllipseHelper, Event, EventCreator, Export, FileHelper, Frame, FrameData, Group, GroupData, Image, ImageData, ImageEvent, ImageManager, IncrementId, LayoutEvent, Layouter, Leaf, LeafBounds, LeafBoundsHelper, LeafData, LeafDataProxy, LeafEventer, LeafHelper, LeafLayout, LeafLevelList, LeafList, LeafMatrix, LeafRender, Leafer, LeaferCanvas, LeaferCanvasBase, LeaferData, LeaferEvent, LeaferImage, Line, LineData, MathHelper, Matrix, MatrixHelper, NeedConvertToCanvasCommandMap, OneRadian, PI2, PI_2, Paint, PaintGradient, PaintImage, Path, PathArrow, PathBounds, PathCommandDataHelper, PathCommandMap, PathConvert, PathCorner, PathCreator, PathData, PathDrawer, PathHelper, PathNumberCommandLengthMap, PathNumberCommandMap, Pen, PenData, Platform, Point, PointHelper, Polygon, PolygonData, PropertyEvent, Rect, RectData, RectHelper, RectRender, RenderEvent, Renderer, ResizeEvent, Run, Star, StarData, State, StringNumberMap, TaskItem, TaskProcessor, Text, TextConvert, TextData, TwoPointBoundsHelper, UI, UIBounds, UICreator, UIData, UIRender, UnitConvert, WaitHelper, WatchEvent, Watcher, affectRenderBoundsType, affectStrokeBoundsType, arrowType, attr, autoLayoutType, boundsType, canvasPatch, canvasSizeAttrs, cursorType, dataProcessor, dataType, decorateLeafAttr, defineDataProcessor, defineKey, defineLeafAttr, doBoundsType, doStrokeType, effectType, emptyData, eraserType, getBoundsData, getDescriptor, getMatrixData, getPointData, hitType, layoutProcessor, maskType, naturalBoundsType, opacityType, pathInputType, pathType, pen, positionType, registerUI, registerUIEvent, resizeType, rewrite, rewriteAble, rotationType, scaleType, sortType, stateType, strokeType, surfaceType, tempBounds$1 as tempBounds, tempMatrix, tempPoint$3 as tempPoint, useCanvas, useModule, version, zoomLayerType };