@leafer/core 1.0.1 → 1.0.3
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/lib/core.cjs +352 -223
- package/lib/core.esm.js +350 -222
- package/lib/core.esm.min.js +1 -1
- package/lib/core.min.cjs +1 -1
- package/package.json +17 -18
- package/src/index.ts +1 -4
- package/types/index.d.ts +2 -4
package/lib/core.esm.js
CHANGED
|
@@ -111,6 +111,26 @@ const MathHelper = {
|
|
|
111
111
|
const a = maxLength ? pow$1(10, maxLength) : 1000000000000;
|
|
112
112
|
num = round(num * a) / a;
|
|
113
113
|
return num === -0 ? 0 : num;
|
|
114
|
+
},
|
|
115
|
+
getScaleData(scale, size, originSize, scaleData) {
|
|
116
|
+
if (!scaleData)
|
|
117
|
+
scaleData = {};
|
|
118
|
+
if (size) {
|
|
119
|
+
scaleData.scaleX = (typeof size === 'number' ? size : size.width) / originSize.width;
|
|
120
|
+
scaleData.scaleY = (typeof size === 'number' ? size : size.height) / originSize.height;
|
|
121
|
+
}
|
|
122
|
+
else if (scale)
|
|
123
|
+
MathHelper.assignScale(scaleData, scale);
|
|
124
|
+
return scaleData;
|
|
125
|
+
},
|
|
126
|
+
assignScale(scaleData, scale) {
|
|
127
|
+
if (typeof scale === 'number') {
|
|
128
|
+
scaleData.scaleX = scaleData.scaleY = scale;
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
scaleData.scaleX = scale.x;
|
|
132
|
+
scaleData.scaleY = scale.y;
|
|
133
|
+
}
|
|
114
134
|
}
|
|
115
135
|
};
|
|
116
136
|
const OneRadian = PI$2 / 180;
|
|
@@ -409,7 +429,7 @@ const MatrixHelper = {
|
|
|
409
429
|
};
|
|
410
430
|
const M$6 = MatrixHelper;
|
|
411
431
|
|
|
412
|
-
const { toInnerPoint: toInnerPoint$2, toOuterPoint: toOuterPoint$
|
|
432
|
+
const { toInnerPoint: toInnerPoint$2, toOuterPoint: toOuterPoint$3 } = MatrixHelper;
|
|
413
433
|
const { sin: sin$2, cos: cos$2, abs: abs$2, sqrt: sqrt$2, atan2: atan2$2, min: min$1, PI: PI$1 } = Math;
|
|
414
434
|
const PointHelper = {
|
|
415
435
|
defaultPoint: getPointData(),
|
|
@@ -465,7 +485,7 @@ const PointHelper = {
|
|
|
465
485
|
tempToOuterOf(t, matrix) {
|
|
466
486
|
const { tempPoint: temp } = P$5;
|
|
467
487
|
copy$7(temp, t);
|
|
468
|
-
toOuterPoint$
|
|
488
|
+
toOuterPoint$3(matrix, temp, temp);
|
|
469
489
|
return temp;
|
|
470
490
|
},
|
|
471
491
|
tempToInnerRadiusPointOf(t, matrix) {
|
|
@@ -484,7 +504,7 @@ const PointHelper = {
|
|
|
484
504
|
toInnerPoint$2(matrix, t, to);
|
|
485
505
|
},
|
|
486
506
|
toOuterOf(t, matrix, to) {
|
|
487
|
-
toOuterPoint$
|
|
507
|
+
toOuterPoint$3(matrix, t, to);
|
|
488
508
|
},
|
|
489
509
|
getCenter(t, to) {
|
|
490
510
|
return { x: t.x + (to.x - t.x) / 2, y: t.y + (to.y - t.y) / 2 };
|
|
@@ -764,7 +784,7 @@ const TwoPointBoundsHelper = {
|
|
|
764
784
|
const { addPoint: addPoint$3 } = TwoPointBoundsHelper;
|
|
765
785
|
|
|
766
786
|
const { tempPointBounds: tempPointBounds$1, setPoint: setPoint$2, addPoint: addPoint$2, toBounds: toBounds$2 } = TwoPointBoundsHelper;
|
|
767
|
-
const { toOuterPoint: toOuterPoint$
|
|
787
|
+
const { toOuterPoint: toOuterPoint$2 } = MatrixHelper;
|
|
768
788
|
const { float, fourNumber } = MathHelper;
|
|
769
789
|
const { floor, ceil: ceil$1 } = Math;
|
|
770
790
|
let right, bottom, boundsRight, boundsBottom;
|
|
@@ -784,17 +804,24 @@ const BoundsHelper = {
|
|
|
784
804
|
t.width = bounds.width;
|
|
785
805
|
t.height = bounds.height;
|
|
786
806
|
},
|
|
787
|
-
copyAndSpread(t, bounds, spread, isShrink) {
|
|
807
|
+
copyAndSpread(t, bounds, spread, isShrink, side) {
|
|
808
|
+
const { x, y, width, height } = bounds;
|
|
788
809
|
if (spread instanceof Array) {
|
|
789
810
|
const four = fourNumber(spread);
|
|
790
811
|
isShrink
|
|
791
|
-
? B.set(t,
|
|
792
|
-
: B.set(t,
|
|
812
|
+
? B.set(t, x + four[3], y + four[0], width - four[1] - four[3], height - four[2] - four[0])
|
|
813
|
+
: B.set(t, x - four[3], y - four[0], width + four[1] + four[3], height + four[2] + four[0]);
|
|
793
814
|
}
|
|
794
815
|
else {
|
|
795
816
|
if (isShrink)
|
|
796
817
|
spread = -spread;
|
|
797
|
-
B.set(t,
|
|
818
|
+
B.set(t, x - spread, y - spread, width + spread * 2, height + spread * 2);
|
|
819
|
+
}
|
|
820
|
+
if (side) {
|
|
821
|
+
if (side === 'width')
|
|
822
|
+
t.y = y, t.height = height;
|
|
823
|
+
else
|
|
824
|
+
t.x = x, t.width = width;
|
|
798
825
|
}
|
|
799
826
|
},
|
|
800
827
|
minX(t) { return t.width > 0 ? t.x : t.x + t.width; },
|
|
@@ -871,16 +898,16 @@ const BoundsHelper = {
|
|
|
871
898
|
else {
|
|
872
899
|
point.x = t.x;
|
|
873
900
|
point.y = t.y;
|
|
874
|
-
toOuterPoint$
|
|
901
|
+
toOuterPoint$2(matrix, point, toPoint$2);
|
|
875
902
|
setPoint$2(tempPointBounds$1, toPoint$2.x, toPoint$2.y);
|
|
876
903
|
point.x = t.x + t.width;
|
|
877
|
-
toOuterPoint$
|
|
904
|
+
toOuterPoint$2(matrix, point, toPoint$2);
|
|
878
905
|
addPoint$2(tempPointBounds$1, toPoint$2.x, toPoint$2.y);
|
|
879
906
|
point.y = t.y + t.height;
|
|
880
|
-
toOuterPoint$
|
|
907
|
+
toOuterPoint$2(matrix, point, toPoint$2);
|
|
881
908
|
addPoint$2(tempPointBounds$1, toPoint$2.x, toPoint$2.y);
|
|
882
909
|
point.x = t.x;
|
|
883
|
-
toOuterPoint$
|
|
910
|
+
toOuterPoint$2(matrix, point, toPoint$2);
|
|
884
911
|
addPoint$2(tempPointBounds$1, toPoint$2.x, toPoint$2.y);
|
|
885
912
|
toBounds$2(tempPointBounds$1, to);
|
|
886
913
|
}
|
|
@@ -894,16 +921,16 @@ const BoundsHelper = {
|
|
|
894
921
|
const scale = Math.min(baseScale, Math.min(t.width / put.width, t.height / put.height));
|
|
895
922
|
return new Matrix(scale, 0, 0, scale, -put.x * scale, -put.y * scale);
|
|
896
923
|
},
|
|
897
|
-
getSpread(t, spread) {
|
|
924
|
+
getSpread(t, spread, side) {
|
|
898
925
|
const n = {};
|
|
899
|
-
B.copyAndSpread(n, t, spread);
|
|
926
|
+
B.copyAndSpread(n, t, spread, false, side);
|
|
900
927
|
return n;
|
|
901
928
|
},
|
|
902
|
-
spread(t, spread) {
|
|
903
|
-
B.copyAndSpread(t, t, spread);
|
|
929
|
+
spread(t, spread, side) {
|
|
930
|
+
B.copyAndSpread(t, t, spread, false, side);
|
|
904
931
|
},
|
|
905
|
-
shrink(t, shrink) {
|
|
906
|
-
B.copyAndSpread(t, t, shrink, true);
|
|
932
|
+
shrink(t, shrink, side) {
|
|
933
|
+
B.copyAndSpread(t, t, shrink, true, side);
|
|
907
934
|
},
|
|
908
935
|
ceil(t) {
|
|
909
936
|
const { x, y } = t;
|
|
@@ -1086,12 +1113,12 @@ class Bounds {
|
|
|
1086
1113
|
getFitMatrix(put, baseScale) {
|
|
1087
1114
|
return BoundsHelper.getFitMatrix(this, put, baseScale);
|
|
1088
1115
|
}
|
|
1089
|
-
spread(fourNumber) {
|
|
1090
|
-
BoundsHelper.spread(this, fourNumber);
|
|
1116
|
+
spread(fourNumber, side) {
|
|
1117
|
+
BoundsHelper.spread(this, fourNumber, side);
|
|
1091
1118
|
return this;
|
|
1092
1119
|
}
|
|
1093
|
-
shrink(fourNumber) {
|
|
1094
|
-
BoundsHelper.shrink(this, fourNumber);
|
|
1120
|
+
shrink(fourNumber, side) {
|
|
1121
|
+
BoundsHelper.shrink(this, fourNumber, side);
|
|
1095
1122
|
return this;
|
|
1096
1123
|
}
|
|
1097
1124
|
ceil() {
|
|
@@ -1235,7 +1262,6 @@ const AroundHelper = {
|
|
|
1235
1262
|
tempPoint: {},
|
|
1236
1263
|
get,
|
|
1237
1264
|
toPoint(around, bounds, to, onlySize, pointBounds) {
|
|
1238
|
-
to || (to = {});
|
|
1239
1265
|
const point = get(around);
|
|
1240
1266
|
to.x = point.x;
|
|
1241
1267
|
to.y = point.y;
|
|
@@ -1370,6 +1396,10 @@ const Run = {
|
|
|
1370
1396
|
};
|
|
1371
1397
|
const R = Run;
|
|
1372
1398
|
|
|
1399
|
+
function needPlugin(name) {
|
|
1400
|
+
console.error('need plugin: @leafer-in/' + name);
|
|
1401
|
+
}
|
|
1402
|
+
|
|
1373
1403
|
const debug$7 = Debug.get('UICreator');
|
|
1374
1404
|
const UICreator = {
|
|
1375
1405
|
list: {},
|
|
@@ -1632,6 +1662,9 @@ var Answer;
|
|
|
1632
1662
|
Answer[Answer["YesAndSkip"] = 3] = "YesAndSkip";
|
|
1633
1663
|
})(Answer || (Answer = {}));
|
|
1634
1664
|
const emptyData = {};
|
|
1665
|
+
function isNull(value) {
|
|
1666
|
+
return value === undefined || value === null;
|
|
1667
|
+
}
|
|
1635
1668
|
|
|
1636
1669
|
/******************************************************************************
|
|
1637
1670
|
Copyright (c) Microsoft Corporation.
|
|
@@ -2397,7 +2430,7 @@ const BezierHelper = {
|
|
|
2397
2430
|
let startY = y = rotationSin * radiusX * startCos + rotationCos * radiusY * startSin;
|
|
2398
2431
|
let fromX = cx + x, fromY = cy + y;
|
|
2399
2432
|
if (data)
|
|
2400
|
-
data.push(L$6, fromX, fromY);
|
|
2433
|
+
data.push(data.length ? L$6 : M$5, fromX, fromY);
|
|
2401
2434
|
if (setPointBounds)
|
|
2402
2435
|
setPoint$1(setPointBounds, fromX, fromY);
|
|
2403
2436
|
if (setStartPoint)
|
|
@@ -2908,60 +2941,75 @@ class PathCreator {
|
|
|
2908
2941
|
}
|
|
2909
2942
|
beginPath() {
|
|
2910
2943
|
beginPath(this.__path);
|
|
2944
|
+
this.paint();
|
|
2911
2945
|
return this;
|
|
2912
2946
|
}
|
|
2913
2947
|
moveTo(x, y) {
|
|
2914
2948
|
moveTo(this.__path, x, y);
|
|
2949
|
+
this.paint();
|
|
2915
2950
|
return this;
|
|
2916
2951
|
}
|
|
2917
2952
|
lineTo(x, y) {
|
|
2918
2953
|
lineTo(this.__path, x, y);
|
|
2954
|
+
this.paint();
|
|
2919
2955
|
return this;
|
|
2920
2956
|
}
|
|
2921
2957
|
bezierCurveTo(x1, y1, x2, y2, x, y) {
|
|
2922
2958
|
bezierCurveTo(this.__path, x1, y1, x2, y2, x, y);
|
|
2959
|
+
this.paint();
|
|
2923
2960
|
return this;
|
|
2924
2961
|
}
|
|
2925
2962
|
quadraticCurveTo(x1, y1, x, y) {
|
|
2926
2963
|
quadraticCurveTo(this.__path, x1, y1, x, y);
|
|
2964
|
+
this.paint();
|
|
2927
2965
|
return this;
|
|
2928
2966
|
}
|
|
2929
2967
|
closePath() {
|
|
2930
2968
|
closePath(this.__path);
|
|
2969
|
+
this.paint();
|
|
2931
2970
|
return this;
|
|
2932
2971
|
}
|
|
2933
2972
|
rect(x, y, width, height) {
|
|
2934
2973
|
rect(this.__path, x, y, width, height);
|
|
2974
|
+
this.paint();
|
|
2935
2975
|
return this;
|
|
2936
2976
|
}
|
|
2937
2977
|
roundRect(x, y, width, height, cornerRadius) {
|
|
2938
2978
|
roundRect$1(this.__path, x, y, width, height, cornerRadius);
|
|
2979
|
+
this.paint();
|
|
2939
2980
|
return this;
|
|
2940
2981
|
}
|
|
2941
2982
|
ellipse(x, y, radiusX, radiusY, rotation, startAngle, endAngle, anticlockwise) {
|
|
2942
2983
|
ellipse$1(this.__path, x, y, radiusX, radiusY, rotation, startAngle, endAngle, anticlockwise);
|
|
2984
|
+
this.paint();
|
|
2943
2985
|
return this;
|
|
2944
2986
|
}
|
|
2945
2987
|
arc(x, y, radius, startAngle, endAngle, anticlockwise) {
|
|
2946
2988
|
arc$1(this.__path, x, y, radius, startAngle, endAngle, anticlockwise);
|
|
2989
|
+
this.paint();
|
|
2947
2990
|
return this;
|
|
2948
2991
|
}
|
|
2949
2992
|
arcTo(x1, y1, x2, y2, radius) {
|
|
2950
2993
|
arcTo$2(this.__path, x1, y1, x2, y2, radius);
|
|
2994
|
+
this.paint();
|
|
2951
2995
|
return this;
|
|
2952
2996
|
}
|
|
2953
2997
|
drawEllipse(x, y, radiusX, radiusY, rotation, startAngle, endAngle, anticlockwise) {
|
|
2954
2998
|
drawEllipse(this.__path, x, y, radiusX, radiusY, rotation, startAngle, endAngle, anticlockwise);
|
|
2999
|
+
this.paint();
|
|
2955
3000
|
return this;
|
|
2956
3001
|
}
|
|
2957
3002
|
drawArc(x, y, radius, startAngle, endAngle, anticlockwise) {
|
|
2958
3003
|
drawArc(this.__path, x, y, radius, startAngle, endAngle, anticlockwise);
|
|
3004
|
+
this.paint();
|
|
2959
3005
|
return this;
|
|
2960
3006
|
}
|
|
2961
3007
|
drawPoints(points, curve, close) {
|
|
2962
3008
|
drawPoints(this.__path, points, curve, close);
|
|
3009
|
+
this.paint();
|
|
2963
3010
|
return this;
|
|
2964
3011
|
}
|
|
3012
|
+
paint() { }
|
|
2965
3013
|
}
|
|
2966
3014
|
|
|
2967
3015
|
const { M: M$2, L: L$3, C: C$2, Q: Q$1, Z: Z$2, N: N$1, D: D$1, X: X$1, G: G$1, F: F$2, O: O$1, P: P$1, U: U$1 } = PathCommandMap;
|
|
@@ -3051,8 +3099,7 @@ const PathBounds = {
|
|
|
3051
3099
|
toTwoPointBounds(data, setPointBounds) {
|
|
3052
3100
|
if (!data || !data.length)
|
|
3053
3101
|
return setPoint(setPointBounds, 0, 0);
|
|
3054
|
-
let command;
|
|
3055
|
-
let i = 0, x = 0, y = 0, x1, y1, toX, toY;
|
|
3102
|
+
let i = 0, x = 0, y = 0, x1, y1, toX, toY, command;
|
|
3056
3103
|
const len = data.length;
|
|
3057
3104
|
while (i < len) {
|
|
3058
3105
|
command = data[i];
|
|
@@ -3708,7 +3755,7 @@ function autoLayoutType(defaultValue) {
|
|
|
3708
3755
|
set(value) {
|
|
3709
3756
|
if (this.__setAttr(key, value)) {
|
|
3710
3757
|
this.__layout.matrixChanged || this.__layout.matrixChange();
|
|
3711
|
-
this.__hasAutoLayout = !!
|
|
3758
|
+
this.__hasAutoLayout = !!(this.origin || this.around || this.flow);
|
|
3712
3759
|
if (!this.__local)
|
|
3713
3760
|
this.__layout.createLocal();
|
|
3714
3761
|
}
|
|
@@ -3801,14 +3848,25 @@ function visibleType(defaultValue) {
|
|
|
3801
3848
|
return decorateLeafAttr(defaultValue, (key) => attr({
|
|
3802
3849
|
set(value) {
|
|
3803
3850
|
const oldValue = this.visible;
|
|
3804
|
-
if (
|
|
3805
|
-
|
|
3806
|
-
|
|
3807
|
-
|
|
3851
|
+
if (oldValue === true && value === 0) {
|
|
3852
|
+
if (this.animationOut)
|
|
3853
|
+
return this.__runAnimation('out', () => doVisible(this, key, value, oldValue));
|
|
3854
|
+
}
|
|
3855
|
+
else if (oldValue === 0 && value === true) {
|
|
3856
|
+
if (this.animation)
|
|
3857
|
+
this.__runAnimation('in');
|
|
3808
3858
|
}
|
|
3859
|
+
doVisible(this, key, value, oldValue);
|
|
3809
3860
|
}
|
|
3810
3861
|
}));
|
|
3811
3862
|
}
|
|
3863
|
+
function doVisible(leaf, key, value, oldValue) {
|
|
3864
|
+
if (leaf.__setAttr(key, value)) {
|
|
3865
|
+
leaf.__layout.opacityChanged || leaf.__layout.opacityChange();
|
|
3866
|
+
if (oldValue === 0 || value === 0)
|
|
3867
|
+
doBoundsType(leaf);
|
|
3868
|
+
}
|
|
3869
|
+
}
|
|
3812
3870
|
function sortType(defaultValue) {
|
|
3813
3871
|
return decorateLeafAttr(defaultValue, (key) => attr({
|
|
3814
3872
|
set(value) {
|
|
@@ -3892,7 +3950,16 @@ function defineDataProcessor(target, key, defaultValue) {
|
|
|
3892
3950
|
if (defaultValue === undefined) {
|
|
3893
3951
|
property.get = function () { return this[computedKey]; };
|
|
3894
3952
|
}
|
|
3895
|
-
else if (
|
|
3953
|
+
else if (typeof defaultValue === 'object') {
|
|
3954
|
+
const { clone } = DataHelper;
|
|
3955
|
+
property.get = function () {
|
|
3956
|
+
let v = this[computedKey];
|
|
3957
|
+
if (v === undefined)
|
|
3958
|
+
this[computedKey] = v = clone(defaultValue);
|
|
3959
|
+
return v;
|
|
3960
|
+
};
|
|
3961
|
+
}
|
|
3962
|
+
if (key === 'width') {
|
|
3896
3963
|
property.get = function () {
|
|
3897
3964
|
const v = this[computedKey];
|
|
3898
3965
|
if (v === undefined) {
|
|
@@ -3983,7 +4050,7 @@ function registerUIEvent() {
|
|
|
3983
4050
|
};
|
|
3984
4051
|
}
|
|
3985
4052
|
|
|
3986
|
-
const { copy: copy$3, toInnerPoint: toInnerPoint$1, scaleOfOuter, rotateOfOuter, skewOfOuter, multiplyParent: multiplyParent$2, divideParent, getLayout } = MatrixHelper;
|
|
4053
|
+
const { copy: copy$3, toInnerPoint: toInnerPoint$1, toOuterPoint: toOuterPoint$1, scaleOfOuter, rotateOfOuter, skewOfOuter, multiplyParent: multiplyParent$2, divideParent, getLayout } = MatrixHelper;
|
|
3987
4054
|
const matrix = {};
|
|
3988
4055
|
const LeafHelper = {
|
|
3989
4056
|
updateAllMatrix(leaf, checkAutoLayout, waitAutoLayout) {
|
|
@@ -4048,10 +4115,9 @@ const LeafHelper = {
|
|
|
4048
4115
|
}
|
|
4049
4116
|
return true;
|
|
4050
4117
|
},
|
|
4051
|
-
moveWorld(t, x, y = 0) {
|
|
4118
|
+
moveWorld(t, x, y = 0, isInnerPoint) {
|
|
4052
4119
|
const local = typeof x === 'object' ? Object.assign({}, x) : { x, y };
|
|
4053
|
-
|
|
4054
|
-
toInnerPoint$1(t.parent.worldTransform, local, local, true);
|
|
4120
|
+
isInnerPoint ? toOuterPoint$1(t.localTransform, local, local, true) : (t.parent && toInnerPoint$1(t.parent.worldTransform, local, local, true));
|
|
4055
4121
|
L.moveLocal(t, local.x, local.y);
|
|
4056
4122
|
},
|
|
4057
4123
|
moveLocal(t, x, y = 0) {
|
|
@@ -4560,144 +4626,6 @@ class LeafLayout {
|
|
|
4560
4626
|
destroy() { }
|
|
4561
4627
|
}
|
|
4562
4628
|
|
|
4563
|
-
const empty = {};
|
|
4564
|
-
const LeafEventer = {
|
|
4565
|
-
on(type, listener, options) {
|
|
4566
|
-
let capture, once;
|
|
4567
|
-
if (options) {
|
|
4568
|
-
if (options === 'once') {
|
|
4569
|
-
once = true;
|
|
4570
|
-
}
|
|
4571
|
-
else if (typeof options === 'boolean') {
|
|
4572
|
-
capture = options;
|
|
4573
|
-
}
|
|
4574
|
-
else {
|
|
4575
|
-
capture = options.capture;
|
|
4576
|
-
once = options.once;
|
|
4577
|
-
}
|
|
4578
|
-
}
|
|
4579
|
-
let events;
|
|
4580
|
-
const map = __getListenerMap(this, capture, true);
|
|
4581
|
-
const typeList = typeof type === 'string' ? type.split(' ') : type;
|
|
4582
|
-
const item = once ? { listener, once } : { listener };
|
|
4583
|
-
typeList.forEach(type => {
|
|
4584
|
-
if (type) {
|
|
4585
|
-
events = map[type];
|
|
4586
|
-
if (events) {
|
|
4587
|
-
if (events.findIndex(item => item.listener === listener) === -1)
|
|
4588
|
-
events.push(item);
|
|
4589
|
-
}
|
|
4590
|
-
else {
|
|
4591
|
-
map[type] = [item];
|
|
4592
|
-
}
|
|
4593
|
-
}
|
|
4594
|
-
});
|
|
4595
|
-
},
|
|
4596
|
-
off(type, listener, options) {
|
|
4597
|
-
if (type) {
|
|
4598
|
-
const typeList = typeof type === 'string' ? type.split(' ') : type;
|
|
4599
|
-
if (listener) {
|
|
4600
|
-
let capture;
|
|
4601
|
-
if (options)
|
|
4602
|
-
capture = typeof options === 'boolean' ? options : (options === 'once' ? false : options.capture);
|
|
4603
|
-
let events, index;
|
|
4604
|
-
const map = __getListenerMap(this, capture);
|
|
4605
|
-
typeList.forEach(type => {
|
|
4606
|
-
if (type) {
|
|
4607
|
-
events = map[type];
|
|
4608
|
-
if (events) {
|
|
4609
|
-
index = events.findIndex(item => item.listener === listener);
|
|
4610
|
-
if (index > -1)
|
|
4611
|
-
events.splice(index, 1);
|
|
4612
|
-
if (!events.length)
|
|
4613
|
-
delete map[type];
|
|
4614
|
-
}
|
|
4615
|
-
}
|
|
4616
|
-
});
|
|
4617
|
-
}
|
|
4618
|
-
else {
|
|
4619
|
-
const { __bubbleMap: b, __captureMap: c } = this;
|
|
4620
|
-
typeList.forEach(type => {
|
|
4621
|
-
if (b)
|
|
4622
|
-
delete b[type];
|
|
4623
|
-
if (c)
|
|
4624
|
-
delete c[type];
|
|
4625
|
-
});
|
|
4626
|
-
}
|
|
4627
|
-
}
|
|
4628
|
-
else {
|
|
4629
|
-
this.__bubbleMap = this.__captureMap = undefined;
|
|
4630
|
-
}
|
|
4631
|
-
},
|
|
4632
|
-
on_(type, listener, bind, options) {
|
|
4633
|
-
if (bind)
|
|
4634
|
-
listener = listener.bind(bind);
|
|
4635
|
-
this.on(type, listener, options);
|
|
4636
|
-
return { type, current: this, listener, options };
|
|
4637
|
-
},
|
|
4638
|
-
off_(id) {
|
|
4639
|
-
if (!id)
|
|
4640
|
-
return;
|
|
4641
|
-
const list = id instanceof Array ? id : [id];
|
|
4642
|
-
list.forEach(item => item.current.off(item.type, item.listener, item.options));
|
|
4643
|
-
list.length = 0;
|
|
4644
|
-
},
|
|
4645
|
-
once(type, listener, capture) {
|
|
4646
|
-
this.on(type, listener, { once: true, capture });
|
|
4647
|
-
},
|
|
4648
|
-
emit(type, event, capture) {
|
|
4649
|
-
if (!event && EventCreator.has(type))
|
|
4650
|
-
event = EventCreator.get(type, { type, target: this, current: this });
|
|
4651
|
-
const map = __getListenerMap(this, capture);
|
|
4652
|
-
const list = map[type];
|
|
4653
|
-
if (list) {
|
|
4654
|
-
let item;
|
|
4655
|
-
for (let i = 0, len = list.length; i < len; i++) {
|
|
4656
|
-
item = list[i];
|
|
4657
|
-
item.listener(event);
|
|
4658
|
-
if (item.once) {
|
|
4659
|
-
this.off(type, item.listener, capture);
|
|
4660
|
-
i--, len--;
|
|
4661
|
-
}
|
|
4662
|
-
if (event && event.isStopNow)
|
|
4663
|
-
break;
|
|
4664
|
-
}
|
|
4665
|
-
}
|
|
4666
|
-
this.syncEventer && this.syncEventer.emitEvent(event, capture);
|
|
4667
|
-
},
|
|
4668
|
-
emitEvent(event, capture) {
|
|
4669
|
-
event.current = this;
|
|
4670
|
-
this.emit(event.type, event, capture);
|
|
4671
|
-
},
|
|
4672
|
-
hasEvent(type, capture) {
|
|
4673
|
-
if (this.syncEventer && this.syncEventer.hasEvent(type, capture))
|
|
4674
|
-
return true;
|
|
4675
|
-
const { __bubbleMap: b, __captureMap: c } = this;
|
|
4676
|
-
const hasB = b && b[type], hasC = c && c[type];
|
|
4677
|
-
return !!(capture === undefined ? (hasB || hasC) : (capture ? hasC : hasB));
|
|
4678
|
-
},
|
|
4679
|
-
};
|
|
4680
|
-
function __getListenerMap(eventer, capture, create) {
|
|
4681
|
-
if (capture) {
|
|
4682
|
-
const { __captureMap: c } = eventer;
|
|
4683
|
-
if (c) {
|
|
4684
|
-
return c;
|
|
4685
|
-
}
|
|
4686
|
-
else {
|
|
4687
|
-
return create ? eventer.__captureMap = {} : empty;
|
|
4688
|
-
}
|
|
4689
|
-
}
|
|
4690
|
-
else {
|
|
4691
|
-
const { __bubbleMap: b } = eventer;
|
|
4692
|
-
if (b) {
|
|
4693
|
-
return b;
|
|
4694
|
-
}
|
|
4695
|
-
else {
|
|
4696
|
-
return create ? eventer.__bubbleMap = {} : empty;
|
|
4697
|
-
}
|
|
4698
|
-
}
|
|
4699
|
-
}
|
|
4700
|
-
|
|
4701
4629
|
class Event {
|
|
4702
4630
|
constructor(type, target) {
|
|
4703
4631
|
this.bubbles = false;
|
|
@@ -4732,7 +4660,10 @@ class ChildEvent extends Event {
|
|
|
4732
4660
|
}
|
|
4733
4661
|
ChildEvent.ADD = 'child.add';
|
|
4734
4662
|
ChildEvent.REMOVE = 'child.remove';
|
|
4735
|
-
ChildEvent.
|
|
4663
|
+
ChildEvent.CREATED = 'created';
|
|
4664
|
+
ChildEvent.MOUNTED = 'mounted';
|
|
4665
|
+
ChildEvent.UNMOUNTED = 'unmounted';
|
|
4666
|
+
ChildEvent.DESTROY = 'destroy';
|
|
4736
4667
|
|
|
4737
4668
|
class PropertyEvent extends Event {
|
|
4738
4669
|
constructor(type, target, attrName, oldValue, newValue) {
|
|
@@ -4810,10 +4741,6 @@ LayoutEvent.AFTER = 'layout.after';
|
|
|
4810
4741
|
LayoutEvent.AGAIN = 'layout.again';
|
|
4811
4742
|
LayoutEvent.END = 'layout.end';
|
|
4812
4743
|
|
|
4813
|
-
class AnimateEvent extends Event {
|
|
4814
|
-
}
|
|
4815
|
-
AnimateEvent.FRAME = 'animate.frame';
|
|
4816
|
-
|
|
4817
4744
|
class RenderEvent extends Event {
|
|
4818
4745
|
constructor(type, times, bounds, options) {
|
|
4819
4746
|
super(type);
|
|
@@ -4846,6 +4773,157 @@ LeaferEvent.STOP = 'leafer.stop';
|
|
|
4846
4773
|
LeaferEvent.RESTART = 'leafer.restart';
|
|
4847
4774
|
LeaferEvent.END = 'leafer.end';
|
|
4848
4775
|
|
|
4776
|
+
const empty = {};
|
|
4777
|
+
class Eventer {
|
|
4778
|
+
set event(map) { this.on(map); }
|
|
4779
|
+
on(type, listener, options) {
|
|
4780
|
+
if (!listener) {
|
|
4781
|
+
let event, map = type;
|
|
4782
|
+
for (let key in map)
|
|
4783
|
+
event = map[key], event instanceof Array ? this.on(key, event[0], event[1]) : this.on(key, event);
|
|
4784
|
+
return;
|
|
4785
|
+
}
|
|
4786
|
+
let capture, once;
|
|
4787
|
+
if (options) {
|
|
4788
|
+
if (options === 'once') {
|
|
4789
|
+
once = true;
|
|
4790
|
+
}
|
|
4791
|
+
else if (typeof options === 'boolean') {
|
|
4792
|
+
capture = options;
|
|
4793
|
+
}
|
|
4794
|
+
else {
|
|
4795
|
+
capture = options.capture;
|
|
4796
|
+
once = options.once;
|
|
4797
|
+
}
|
|
4798
|
+
}
|
|
4799
|
+
let events;
|
|
4800
|
+
const map = __getListenerMap(this, capture, true);
|
|
4801
|
+
const typeList = typeof type === 'string' ? type.split(' ') : type;
|
|
4802
|
+
const item = once ? { listener, once } : { listener };
|
|
4803
|
+
typeList.forEach(type => {
|
|
4804
|
+
if (type) {
|
|
4805
|
+
events = map[type];
|
|
4806
|
+
if (events) {
|
|
4807
|
+
if (events.findIndex(item => item.listener === listener) === -1)
|
|
4808
|
+
events.push(item);
|
|
4809
|
+
}
|
|
4810
|
+
else {
|
|
4811
|
+
map[type] = [item];
|
|
4812
|
+
}
|
|
4813
|
+
}
|
|
4814
|
+
});
|
|
4815
|
+
}
|
|
4816
|
+
off(type, listener, options) {
|
|
4817
|
+
if (type) {
|
|
4818
|
+
const typeList = typeof type === 'string' ? type.split(' ') : type;
|
|
4819
|
+
if (listener) {
|
|
4820
|
+
let capture;
|
|
4821
|
+
if (options)
|
|
4822
|
+
capture = typeof options === 'boolean' ? options : (options === 'once' ? false : options.capture);
|
|
4823
|
+
let events, index;
|
|
4824
|
+
const map = __getListenerMap(this, capture);
|
|
4825
|
+
typeList.forEach(type => {
|
|
4826
|
+
if (type) {
|
|
4827
|
+
events = map[type];
|
|
4828
|
+
if (events) {
|
|
4829
|
+
index = events.findIndex(item => item.listener === listener);
|
|
4830
|
+
if (index > -1)
|
|
4831
|
+
events.splice(index, 1);
|
|
4832
|
+
if (!events.length)
|
|
4833
|
+
delete map[type];
|
|
4834
|
+
}
|
|
4835
|
+
}
|
|
4836
|
+
});
|
|
4837
|
+
}
|
|
4838
|
+
else {
|
|
4839
|
+
const { __bubbleMap: b, __captureMap: c } = this;
|
|
4840
|
+
typeList.forEach(type => {
|
|
4841
|
+
if (b)
|
|
4842
|
+
delete b[type];
|
|
4843
|
+
if (c)
|
|
4844
|
+
delete c[type];
|
|
4845
|
+
});
|
|
4846
|
+
}
|
|
4847
|
+
}
|
|
4848
|
+
else {
|
|
4849
|
+
this.__bubbleMap = this.__captureMap = undefined;
|
|
4850
|
+
}
|
|
4851
|
+
}
|
|
4852
|
+
on_(type, listener, bind, options) {
|
|
4853
|
+
if (bind)
|
|
4854
|
+
listener = listener.bind(bind);
|
|
4855
|
+
this.on(type, listener, options);
|
|
4856
|
+
return { type, current: this, listener, options };
|
|
4857
|
+
}
|
|
4858
|
+
off_(id) {
|
|
4859
|
+
if (!id)
|
|
4860
|
+
return;
|
|
4861
|
+
const list = id instanceof Array ? id : [id];
|
|
4862
|
+
list.forEach(item => item.current.off(item.type, item.listener, item.options));
|
|
4863
|
+
list.length = 0;
|
|
4864
|
+
}
|
|
4865
|
+
once(type, listener, capture) {
|
|
4866
|
+
this.on(type, listener, { once: true, capture });
|
|
4867
|
+
}
|
|
4868
|
+
emit(type, event, capture) {
|
|
4869
|
+
if (!event && EventCreator.has(type))
|
|
4870
|
+
event = EventCreator.get(type, { type, target: this, current: this });
|
|
4871
|
+
const map = __getListenerMap(this, capture);
|
|
4872
|
+
const list = map[type];
|
|
4873
|
+
if (list) {
|
|
4874
|
+
let item;
|
|
4875
|
+
for (let i = 0, len = list.length; i < len; i++) {
|
|
4876
|
+
item = list[i];
|
|
4877
|
+
item.listener(event);
|
|
4878
|
+
if (item.once) {
|
|
4879
|
+
this.off(type, item.listener, capture);
|
|
4880
|
+
i--, len--;
|
|
4881
|
+
}
|
|
4882
|
+
if (event && event.isStopNow)
|
|
4883
|
+
break;
|
|
4884
|
+
}
|
|
4885
|
+
}
|
|
4886
|
+
this.syncEventer && this.syncEventer.emitEvent(event, capture);
|
|
4887
|
+
}
|
|
4888
|
+
emitEvent(event, capture) {
|
|
4889
|
+
event.current = this;
|
|
4890
|
+
this.emit(event.type, event, capture);
|
|
4891
|
+
}
|
|
4892
|
+
hasEvent(type, capture) {
|
|
4893
|
+
if (this.syncEventer && this.syncEventer.hasEvent(type, capture))
|
|
4894
|
+
return true;
|
|
4895
|
+
const { __bubbleMap: b, __captureMap: c } = this;
|
|
4896
|
+
const hasB = b && b[type], hasC = c && c[type];
|
|
4897
|
+
return !!(capture === undefined ? (hasB || hasC) : (capture ? hasC : hasB));
|
|
4898
|
+
}
|
|
4899
|
+
destroy() {
|
|
4900
|
+
this.__captureMap = this.__bubbleMap = this.syncEventer = null;
|
|
4901
|
+
}
|
|
4902
|
+
}
|
|
4903
|
+
function __getListenerMap(eventer, capture, create) {
|
|
4904
|
+
if (capture) {
|
|
4905
|
+
const { __captureMap: c } = eventer;
|
|
4906
|
+
if (c) {
|
|
4907
|
+
return c;
|
|
4908
|
+
}
|
|
4909
|
+
else {
|
|
4910
|
+
return create ? eventer.__captureMap = {} : empty;
|
|
4911
|
+
}
|
|
4912
|
+
}
|
|
4913
|
+
else {
|
|
4914
|
+
const { __bubbleMap: b } = eventer;
|
|
4915
|
+
if (b) {
|
|
4916
|
+
return b;
|
|
4917
|
+
}
|
|
4918
|
+
else {
|
|
4919
|
+
return create ? eventer.__bubbleMap = {} : empty;
|
|
4920
|
+
}
|
|
4921
|
+
}
|
|
4922
|
+
}
|
|
4923
|
+
|
|
4924
|
+
const { on, on_, off, off_, once, emit, emitEvent, hasEvent, destroy } = Eventer.prototype;
|
|
4925
|
+
const LeafEventer = { on, on_, off, off_, once, emit, emitEvent, hasEvent, destroyEventer: destroy };
|
|
4926
|
+
|
|
4849
4927
|
const { isFinite } = Number;
|
|
4850
4928
|
const debug = Debug.get('setAttr');
|
|
4851
4929
|
const LeafDataProxy = {
|
|
@@ -4857,9 +4935,7 @@ const LeafDataProxy = {
|
|
|
4857
4935
|
newValue = undefined;
|
|
4858
4936
|
}
|
|
4859
4937
|
if (typeof newValue === 'object' || oldValue !== newValue) {
|
|
4860
|
-
this.
|
|
4861
|
-
if (this.__proxyData)
|
|
4862
|
-
this.setProxyAttr(name, newValue);
|
|
4938
|
+
this.__realSetAttr(name, newValue);
|
|
4863
4939
|
const { CHANGE } = PropertyEvent;
|
|
4864
4940
|
const event = new PropertyEvent(CHANGE, this, name, oldValue, newValue);
|
|
4865
4941
|
if (this.isLeafer) {
|
|
@@ -4877,12 +4953,18 @@ const LeafDataProxy = {
|
|
|
4877
4953
|
}
|
|
4878
4954
|
}
|
|
4879
4955
|
else {
|
|
4880
|
-
this.
|
|
4881
|
-
if (this.__proxyData)
|
|
4882
|
-
this.setProxyAttr(name, newValue);
|
|
4956
|
+
this.__realSetAttr(name, newValue);
|
|
4883
4957
|
return true;
|
|
4884
4958
|
}
|
|
4885
4959
|
},
|
|
4960
|
+
__realSetAttr(name, newValue) {
|
|
4961
|
+
const data = this.__;
|
|
4962
|
+
data[name] = newValue;
|
|
4963
|
+
if (this.__proxyData)
|
|
4964
|
+
this.setProxyAttr(name, newValue);
|
|
4965
|
+
if (data.normalStyle)
|
|
4966
|
+
this.lockNormalStyle || data.normalStyle[name] === undefined || (data.normalStyle[name] = newValue);
|
|
4967
|
+
},
|
|
4886
4968
|
__getAttr(name) {
|
|
4887
4969
|
if (this.__proxyData)
|
|
4888
4970
|
return this.getProxyAttr(name);
|
|
@@ -4985,6 +5067,8 @@ const LeafBounds = {
|
|
|
4985
5067
|
layout.boundsChanged = false;
|
|
4986
5068
|
},
|
|
4987
5069
|
__updateLocalBoxBounds() {
|
|
5070
|
+
if (this.__hasMotionPath)
|
|
5071
|
+
this.__updateMotionPath();
|
|
4988
5072
|
if (this.__hasAutoLayout)
|
|
4989
5073
|
this.__updateAutoLayout();
|
|
4990
5074
|
toOuterOf$1(this.__layout.boxBounds, this.__local, this.__local);
|
|
@@ -5019,7 +5103,7 @@ const LeafBounds = {
|
|
|
5019
5103
|
updateAllMatrix(this);
|
|
5020
5104
|
updateBounds(this, this);
|
|
5021
5105
|
if (this.__.__autoSide)
|
|
5022
|
-
this.__updateBoxBounds();
|
|
5106
|
+
this.__updateBoxBounds(true);
|
|
5023
5107
|
}
|
|
5024
5108
|
else {
|
|
5025
5109
|
updateAllMatrix(this);
|
|
@@ -5137,7 +5221,7 @@ const BranchRender = {
|
|
|
5137
5221
|
const { LEAF, create } = IncrementId;
|
|
5138
5222
|
const { toInnerPoint, toOuterPoint, multiplyParent } = MatrixHelper;
|
|
5139
5223
|
const { toOuterOf } = BoundsHelper;
|
|
5140
|
-
const { copy } = PointHelper;
|
|
5224
|
+
const { copy, move } = PointHelper;
|
|
5141
5225
|
const { moveLocal, zoomOfLocal, rotateOfLocal, skewOfLocal, moveWorld, zoomOfWorld, rotateOfWorld, skewOfWorld, transform, transformWorld, setTransform, getFlipTransform, getLocalOrigin, getRelativeWorld, drop } = LeafHelper;
|
|
5142
5226
|
let Leaf = class Leaf {
|
|
5143
5227
|
get tag() { return this.__tag; }
|
|
@@ -5164,13 +5248,16 @@ let Leaf = class Leaf {
|
|
|
5164
5248
|
get __ignoreHitWorld() { return (this.__hasMask || this.__hasEraser) && this.__.hitChildren; }
|
|
5165
5249
|
get __inLazyBounds() { const { leafer } = this; return leafer && leafer.created && leafer.lazyBounds.hit(this.__world); }
|
|
5166
5250
|
get pathInputed() { return this.__.__pathInputed; }
|
|
5167
|
-
set event(map) {
|
|
5168
|
-
event = map[key], event instanceof Array ? this.on(key, event[0], event[1]) : this.on(key, event); }
|
|
5251
|
+
set event(map) { this.on(map); }
|
|
5169
5252
|
constructor(data) {
|
|
5170
5253
|
this.innerId = create(LEAF);
|
|
5171
5254
|
this.reset(data);
|
|
5255
|
+
if (this.__bubbleMap)
|
|
5256
|
+
this.__emitLifeEvent(ChildEvent.CREATED);
|
|
5172
5257
|
}
|
|
5173
5258
|
reset(data) {
|
|
5259
|
+
if (this.leafer)
|
|
5260
|
+
this.leafer.forceRender(this.__world);
|
|
5174
5261
|
this.__world = { a: 1, b: 0, c: 0, d: 1, e: 0, f: 0, x: 0, y: 0, width: 0, height: 0, scaleX: 1, scaleY: 1 };
|
|
5175
5262
|
if (data !== null)
|
|
5176
5263
|
this.__local = { a: 1, b: 0, c: 0, d: 1, e: 0, f: 0, x: 0, y: 0, width: 0, height: 0 };
|
|
@@ -5192,12 +5279,12 @@ let Leaf = class Leaf {
|
|
|
5192
5279
|
waitParent(item, bind) {
|
|
5193
5280
|
if (bind)
|
|
5194
5281
|
item = item.bind(bind);
|
|
5195
|
-
this.parent ? item() :
|
|
5282
|
+
this.parent ? item() : this.on(ChildEvent.ADD, item, 'once');
|
|
5196
5283
|
}
|
|
5197
5284
|
waitLeafer(item, bind) {
|
|
5198
5285
|
if (bind)
|
|
5199
5286
|
item = item.bind(bind);
|
|
5200
|
-
this.leafer ? item() :
|
|
5287
|
+
this.leafer ? item() : this.on(ChildEvent.MOUNTED, item, 'once');
|
|
5201
5288
|
}
|
|
5202
5289
|
nextRender(item, bind, off) {
|
|
5203
5290
|
this.leafer ? this.leafer.nextRender(item, bind, off) : this.waitLeafer(() => this.leafer.nextRender(item, bind, off));
|
|
@@ -5206,18 +5293,21 @@ let Leaf = class Leaf {
|
|
|
5206
5293
|
this.nextRender(item, null, 'off');
|
|
5207
5294
|
}
|
|
5208
5295
|
__bindLeafer(leafer) {
|
|
5209
|
-
if (this.isLeafer)
|
|
5210
|
-
|
|
5211
|
-
leafer = this;
|
|
5212
|
-
}
|
|
5296
|
+
if (this.isLeafer && leafer !== null)
|
|
5297
|
+
leafer = this;
|
|
5213
5298
|
if (this.leafer && !leafer)
|
|
5214
5299
|
this.leafer.leafs--;
|
|
5215
5300
|
this.leafer = leafer;
|
|
5216
5301
|
if (leafer) {
|
|
5217
5302
|
leafer.leafs++;
|
|
5218
5303
|
this.__level = this.parent ? this.parent.__level + 1 : 1;
|
|
5219
|
-
if (this.
|
|
5220
|
-
|
|
5304
|
+
if (this.animation)
|
|
5305
|
+
this.__runAnimation('in');
|
|
5306
|
+
if (this.__bubbleMap)
|
|
5307
|
+
this.__emitLifeEvent(ChildEvent.MOUNTED);
|
|
5308
|
+
}
|
|
5309
|
+
else {
|
|
5310
|
+
this.__emitLifeEvent(ChildEvent.UNMOUNTED);
|
|
5221
5311
|
}
|
|
5222
5312
|
if (this.isBranch) {
|
|
5223
5313
|
const { children } = this;
|
|
@@ -5226,7 +5316,7 @@ let Leaf = class Leaf {
|
|
|
5226
5316
|
}
|
|
5227
5317
|
}
|
|
5228
5318
|
}
|
|
5229
|
-
set(_data) { }
|
|
5319
|
+
set(_data, _isTemp) { }
|
|
5230
5320
|
get(_name) { return undefined; }
|
|
5231
5321
|
setAttr(name, value) { this[name] = value; }
|
|
5232
5322
|
getAttr(name) { return this[name]; }
|
|
@@ -5251,6 +5341,7 @@ let Leaf = class Leaf {
|
|
|
5251
5341
|
findOne(_condition, _options) { return undefined; }
|
|
5252
5342
|
findId(_id) { return undefined; }
|
|
5253
5343
|
focus(_value) { }
|
|
5344
|
+
updateState() { }
|
|
5254
5345
|
updateLayout() {
|
|
5255
5346
|
this.__layout.update();
|
|
5256
5347
|
}
|
|
@@ -5358,11 +5449,24 @@ let Leaf = class Leaf {
|
|
|
5358
5449
|
if (relative)
|
|
5359
5450
|
relative.worldToInner(to ? to : inner, null, distance);
|
|
5360
5451
|
}
|
|
5452
|
+
getBoxPoint(world, relative, distance, change) {
|
|
5453
|
+
return this.getBoxPointByInner(this.getInnerPoint(world, relative, distance, change), null, null, true);
|
|
5454
|
+
}
|
|
5455
|
+
getBoxPointByInner(inner, _relative, _distance, change) {
|
|
5456
|
+
const point = change ? inner : Object.assign({}, inner), { x, y } = this.boxBounds;
|
|
5457
|
+
move(point, -x, -y);
|
|
5458
|
+
return point;
|
|
5459
|
+
}
|
|
5361
5460
|
getInnerPoint(world, relative, distance, change) {
|
|
5362
5461
|
const point = change ? world : {};
|
|
5363
5462
|
this.worldToInner(world, point, distance, relative);
|
|
5364
5463
|
return point;
|
|
5365
5464
|
}
|
|
5465
|
+
getInnerPointByBox(box, _relative, _distance, change) {
|
|
5466
|
+
const point = change ? box : Object.assign({}, box), { x, y } = this.boxBounds;
|
|
5467
|
+
move(point, x, y);
|
|
5468
|
+
return point;
|
|
5469
|
+
}
|
|
5366
5470
|
getInnerPointByLocal(local, _relative, distance, change) {
|
|
5367
5471
|
return this.getInnerPoint(local, this.parent, distance, change);
|
|
5368
5472
|
}
|
|
@@ -5374,20 +5478,23 @@ let Leaf = class Leaf {
|
|
|
5374
5478
|
getLocalPointByInner(inner, _relative, distance, change) {
|
|
5375
5479
|
return this.getWorldPoint(inner, this.parent, distance, change);
|
|
5376
5480
|
}
|
|
5481
|
+
getPagePoint(world, relative, distance, change) {
|
|
5482
|
+
const layer = this.leafer ? this.leafer.zoomLayer : this;
|
|
5483
|
+
return layer.getInnerPoint(world, relative, distance, change);
|
|
5484
|
+
}
|
|
5377
5485
|
getWorldPoint(inner, relative, distance, change) {
|
|
5378
5486
|
const point = change ? inner : {};
|
|
5379
5487
|
this.innerToWorld(inner, point, distance, relative);
|
|
5380
5488
|
return point;
|
|
5381
5489
|
}
|
|
5490
|
+
getWorldPointByBox(box, relative, distance, change) {
|
|
5491
|
+
return this.getWorldPoint(this.getInnerPointByBox(box, null, null, change), relative, distance, true);
|
|
5492
|
+
}
|
|
5382
5493
|
getWorldPointByLocal(local, relative, distance, change) {
|
|
5383
5494
|
const point = change ? local : {};
|
|
5384
5495
|
this.localToWorld(local, point, distance, relative);
|
|
5385
5496
|
return point;
|
|
5386
5497
|
}
|
|
5387
|
-
getPagePoint(world, relative, distance, change) {
|
|
5388
|
-
const layer = this.leafer ? this.leafer.zoomLayer : this;
|
|
5389
|
-
return layer.getInnerPoint(world, relative, distance, change);
|
|
5390
|
-
}
|
|
5391
5498
|
getWorldPointByPage(page, relative, distance, change) {
|
|
5392
5499
|
const layer = this.leafer ? this.leafer.zoomLayer : this;
|
|
5393
5500
|
return layer.getWorldPoint(page, relative, distance, change);
|
|
@@ -5401,6 +5508,9 @@ let Leaf = class Leaf {
|
|
|
5401
5508
|
move(x, y) {
|
|
5402
5509
|
moveLocal(this, x, y);
|
|
5403
5510
|
}
|
|
5511
|
+
moveInner(x, y) {
|
|
5512
|
+
moveWorld(this, x, y, true);
|
|
5513
|
+
}
|
|
5404
5514
|
scaleOf(origin, scaleX, scaleY, resize) {
|
|
5405
5515
|
zoomOfLocal(this, getLocalOrigin(this, origin), scaleX, scaleY, resize);
|
|
5406
5516
|
}
|
|
@@ -5453,6 +5563,17 @@ let Leaf = class Leaf {
|
|
|
5453
5563
|
__drawRenderPath(_canvas) { }
|
|
5454
5564
|
__updatePath() { }
|
|
5455
5565
|
__updateRenderPath() { }
|
|
5566
|
+
getMotionPathData() {
|
|
5567
|
+
return needPlugin('path');
|
|
5568
|
+
}
|
|
5569
|
+
getMotionPoint(_motionDistance) {
|
|
5570
|
+
return needPlugin('path');
|
|
5571
|
+
}
|
|
5572
|
+
getMotionTotal() {
|
|
5573
|
+
return 0;
|
|
5574
|
+
}
|
|
5575
|
+
__updateMotionPath() { }
|
|
5576
|
+
__runAnimation(_type, _complete) { }
|
|
5456
5577
|
__updateSortChildren() { }
|
|
5457
5578
|
add(_child, _index) { }
|
|
5458
5579
|
remove(_child, destroy) {
|
|
@@ -5478,6 +5599,10 @@ let Leaf = class Leaf {
|
|
|
5478
5599
|
fn = boundsType;
|
|
5479
5600
|
fn(defaultValue)(this.prototype, attrName);
|
|
5480
5601
|
}
|
|
5602
|
+
__emitLifeEvent(type) {
|
|
5603
|
+
if (this.hasEvent(type))
|
|
5604
|
+
this.emitEvent(new ChildEvent(type, this, this.parent));
|
|
5605
|
+
}
|
|
5481
5606
|
destroy() {
|
|
5482
5607
|
if (!this.destroyed) {
|
|
5483
5608
|
const { parent } = this;
|
|
@@ -5485,11 +5610,10 @@ let Leaf = class Leaf {
|
|
|
5485
5610
|
this.remove();
|
|
5486
5611
|
if (this.children)
|
|
5487
5612
|
this.removeAll(true);
|
|
5488
|
-
|
|
5489
|
-
this.emitEvent(new ChildEvent(ChildEvent.DESTROY, this, parent));
|
|
5613
|
+
this.__emitLifeEvent(ChildEvent.DESTROY);
|
|
5490
5614
|
this.__.destroy();
|
|
5491
5615
|
this.__layout.destroy();
|
|
5492
|
-
this.
|
|
5616
|
+
this.destroyEventer();
|
|
5493
5617
|
this.destroyed = true;
|
|
5494
5618
|
}
|
|
5495
5619
|
}
|
|
@@ -5555,8 +5679,8 @@ let Branch = class Branch extends Leaf {
|
|
|
5555
5679
|
this.__.__childBranchNumber = (this.__.__childBranchNumber || 0) + 1;
|
|
5556
5680
|
child.__layout.boxChanged || child.__layout.boxChange();
|
|
5557
5681
|
child.__layout.matrixChanged || child.__layout.matrixChange();
|
|
5558
|
-
if (child.
|
|
5559
|
-
|
|
5682
|
+
if (child.__bubbleMap)
|
|
5683
|
+
child.__emitLifeEvent(ChildEvent.ADD);
|
|
5560
5684
|
if (this.leafer) {
|
|
5561
5685
|
child.__bindLeafer(this.leafer);
|
|
5562
5686
|
if (this.leafer.created)
|
|
@@ -5569,16 +5693,10 @@ let Branch = class Branch extends Leaf {
|
|
|
5569
5693
|
}
|
|
5570
5694
|
remove(child, destroy) {
|
|
5571
5695
|
if (child) {
|
|
5572
|
-
|
|
5573
|
-
|
|
5574
|
-
|
|
5575
|
-
|
|
5576
|
-
this.__.__childBranchNumber = (this.__.__childBranchNumber || 1) - 1;
|
|
5577
|
-
this.__preRemove();
|
|
5578
|
-
this.__realRemoveChild(child);
|
|
5579
|
-
if (destroy)
|
|
5580
|
-
child.destroy();
|
|
5581
|
-
}
|
|
5696
|
+
if (child.animationOut)
|
|
5697
|
+
child.__runAnimation('out', () => this.__remove(child, destroy));
|
|
5698
|
+
else
|
|
5699
|
+
this.__remove(child, destroy);
|
|
5582
5700
|
}
|
|
5583
5701
|
else if (child === undefined) {
|
|
5584
5702
|
super.remove(null, destroy);
|
|
@@ -5600,6 +5718,18 @@ let Branch = class Branch extends Leaf {
|
|
|
5600
5718
|
clear() {
|
|
5601
5719
|
this.removeAll(true);
|
|
5602
5720
|
}
|
|
5721
|
+
__remove(child, destroy) {
|
|
5722
|
+
const index = this.children.indexOf(child);
|
|
5723
|
+
if (index > -1) {
|
|
5724
|
+
this.children.splice(index, 1);
|
|
5725
|
+
if (child.isBranch)
|
|
5726
|
+
this.__.__childBranchNumber = (this.__.__childBranchNumber || 1) - 1;
|
|
5727
|
+
this.__preRemove();
|
|
5728
|
+
this.__realRemoveChild(child);
|
|
5729
|
+
if (destroy)
|
|
5730
|
+
child.destroy();
|
|
5731
|
+
}
|
|
5732
|
+
}
|
|
5603
5733
|
__preRemove() {
|
|
5604
5734
|
if (this.__hasMask)
|
|
5605
5735
|
this.__updateMask();
|
|
@@ -5609,6 +5739,7 @@ let Branch = class Branch extends Leaf {
|
|
|
5609
5739
|
this.__layout.affectChildrenSort && this.__layout.childrenSortChange();
|
|
5610
5740
|
}
|
|
5611
5741
|
__realRemoveChild(child) {
|
|
5742
|
+
child.__emitLifeEvent(ChildEvent.REMOVE);
|
|
5612
5743
|
child.parent = null;
|
|
5613
5744
|
if (this.leafer) {
|
|
5614
5745
|
child.__bindLeafer(null);
|
|
@@ -5621,8 +5752,6 @@ let Branch = class Branch extends Leaf {
|
|
|
5621
5752
|
}
|
|
5622
5753
|
__emitChildEvent(type, child) {
|
|
5623
5754
|
const event = new ChildEvent(type, child, this);
|
|
5624
|
-
if (child.hasEvent(type))
|
|
5625
|
-
child.emitEvent(event);
|
|
5626
5755
|
if (this.hasEvent(type) && !this.isLeafer)
|
|
5627
5756
|
this.emitEvent(event);
|
|
5628
5757
|
this.leafer.emitEvent(event);
|
|
@@ -5785,7 +5914,6 @@ class LeafLevelList {
|
|
|
5785
5914
|
}
|
|
5786
5915
|
}
|
|
5787
5916
|
|
|
5788
|
-
const version = "1.0.
|
|
5789
|
-
const inviteCode = {};
|
|
5917
|
+
const version = "1.0.3";
|
|
5790
5918
|
|
|
5791
|
-
export { AlignHelper,
|
|
5919
|
+
export { AlignHelper, Answer, AroundHelper, AutoBounds, BezierHelper, Bounds, BoundsHelper, Branch, BranchHelper, BranchRender, CanvasManager, ChildEvent, Creator, DataHelper, Debug, Direction4, Direction9, EllipseHelper, Event, EventCreator, Eventer, FileHelper, ImageEvent, ImageManager, IncrementId, LayoutEvent, Leaf, LeafBounds, LeafBoundsHelper, LeafData, LeafDataProxy, LeafEventer, LeafHelper, LeafLayout, LeafLevelList, LeafList, LeafMatrix, LeafRender, LeaferCanvasBase, LeaferEvent, LeaferImage, MathHelper, Matrix, MatrixHelper, NeedConvertToCanvasCommandMap, OneRadian, PI2, PI_2, PathBounds, PathCommandDataHelper, PathCommandMap, PathConvert, PathCorner, PathCreator, PathDrawer, PathHelper, PathNumberCommandLengthMap, PathNumberCommandMap, Platform, Point, PointHelper, PropertyEvent, RectHelper, RenderEvent, ResizeEvent, Run, StringNumberMap, TaskItem, TaskProcessor, TwoPointBoundsHelper, UICreator, WaitHelper, WatchEvent, affectRenderBoundsType, affectStrokeBoundsType, attr, autoLayoutType, boundsType, canvasPatch, canvasSizeAttrs, cursorType, dataProcessor, dataType, decorateLeafAttr, defineDataProcessor, defineKey, defineLeafAttr, doBoundsType, doStrokeType, emptyData, eraserType, getBoundsData, getDescriptor, getMatrixData, getPointData, hitType, isNull, layoutProcessor, maskType, naturalBoundsType, needPlugin, opacityType, pathInputType, pathType, pen, positionType, registerUI, registerUIEvent, rewrite, rewriteAble, rotationType, scaleType, sortType, strokeType, surfaceType, tempBounds, tempMatrix, tempPoint$2 as tempPoint, useModule, version, visibleType };
|