@leafer-ui/miniapp 1.0.2 → 1.0.4
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/dist/miniapp.cjs +34 -21
- package/dist/miniapp.esm.js +35 -22
- package/dist/miniapp.esm.min.js +1 -1
- package/dist/miniapp.min.cjs +1 -1
- package/dist/miniapp.module.js +409 -358
- package/dist/miniapp.module.min.js +1 -1
- package/package.json +10 -10
- package/src/index.ts +2 -0
- package/types/index.d.ts +1 -0
package/dist/miniapp.module.js
CHANGED
|
@@ -119,11 +119,18 @@ const MathHelper = {
|
|
|
119
119
|
scaleData.scaleX = (typeof size === 'number' ? size : size.width) / originSize.width;
|
|
120
120
|
scaleData.scaleY = (typeof size === 'number' ? size : size.height) / originSize.height;
|
|
121
121
|
}
|
|
122
|
-
else if (scale)
|
|
123
|
-
scaleData
|
|
124
|
-
scaleData.scaleY = typeof scale === 'number' ? scale : scale.y;
|
|
125
|
-
}
|
|
122
|
+
else if (scale)
|
|
123
|
+
MathHelper.assignScale(scaleData, scale);
|
|
126
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
|
+
}
|
|
127
134
|
}
|
|
128
135
|
};
|
|
129
136
|
const OneRadian = PI$4 / 180;
|
|
@@ -1255,7 +1262,6 @@ const AroundHelper = {
|
|
|
1255
1262
|
tempPoint: {},
|
|
1256
1263
|
get: get$4,
|
|
1257
1264
|
toPoint(around, bounds, to, onlySize, pointBounds) {
|
|
1258
|
-
to || (to = {});
|
|
1259
1265
|
const point = get$4(around);
|
|
1260
1266
|
to.x = point.x;
|
|
1261
1267
|
to.y = point.y;
|
|
@@ -1390,6 +1396,10 @@ const Run = {
|
|
|
1390
1396
|
};
|
|
1391
1397
|
const R = Run;
|
|
1392
1398
|
|
|
1399
|
+
function needPlugin(name) {
|
|
1400
|
+
console.error('need plugin: @leafer-in/' + name);
|
|
1401
|
+
}
|
|
1402
|
+
|
|
1393
1403
|
const debug$e = Debug.get('UICreator');
|
|
1394
1404
|
const UICreator = {
|
|
1395
1405
|
list: {},
|
|
@@ -1652,6 +1662,9 @@ var Answer;
|
|
|
1652
1662
|
Answer[Answer["YesAndSkip"] = 3] = "YesAndSkip";
|
|
1653
1663
|
})(Answer || (Answer = {}));
|
|
1654
1664
|
const emptyData = {};
|
|
1665
|
+
function isNull(value) {
|
|
1666
|
+
return value === undefined || value === null;
|
|
1667
|
+
}
|
|
1655
1668
|
|
|
1656
1669
|
/******************************************************************************
|
|
1657
1670
|
Copyright (c) Microsoft Corporation.
|
|
@@ -2417,7 +2430,7 @@ const BezierHelper = {
|
|
|
2417
2430
|
let startY = y = rotationSin * radiusX * startCos + rotationCos * radiusY * startSin;
|
|
2418
2431
|
let fromX = cx + x, fromY = cy + y;
|
|
2419
2432
|
if (data)
|
|
2420
|
-
data.push(L$6, fromX, fromY);
|
|
2433
|
+
data.push(data.length ? L$6 : M$5, fromX, fromY);
|
|
2421
2434
|
if (setPointBounds)
|
|
2422
2435
|
setPoint$2(setPointBounds, fromX, fromY);
|
|
2423
2436
|
if (setStartPoint)
|
|
@@ -3086,8 +3099,7 @@ const PathBounds = {
|
|
|
3086
3099
|
toTwoPointBounds(data, setPointBounds) {
|
|
3087
3100
|
if (!data || !data.length)
|
|
3088
3101
|
return setPoint$1(setPointBounds, 0, 0);
|
|
3089
|
-
let command;
|
|
3090
|
-
let i = 0, x = 0, y = 0, x1, y1, toX, toY;
|
|
3102
|
+
let i = 0, x = 0, y = 0, x1, y1, toX, toY, command;
|
|
3091
3103
|
const len = data.length;
|
|
3092
3104
|
while (i < len) {
|
|
3093
3105
|
command = data[i];
|
|
@@ -3743,7 +3755,7 @@ function autoLayoutType(defaultValue) {
|
|
|
3743
3755
|
set(value) {
|
|
3744
3756
|
if (this.__setAttr(key, value)) {
|
|
3745
3757
|
this.__layout.matrixChanged || this.__layout.matrixChange();
|
|
3746
|
-
this.__hasAutoLayout = !!
|
|
3758
|
+
this.__hasAutoLayout = !!(this.origin || this.around || this.flow);
|
|
3747
3759
|
if (!this.__local)
|
|
3748
3760
|
this.__layout.createLocal();
|
|
3749
3761
|
}
|
|
@@ -3836,14 +3848,25 @@ function visibleType(defaultValue) {
|
|
|
3836
3848
|
return decorateLeafAttr(defaultValue, (key) => attr({
|
|
3837
3849
|
set(value) {
|
|
3838
3850
|
const oldValue = this.visible;
|
|
3839
|
-
if (
|
|
3840
|
-
|
|
3841
|
-
|
|
3842
|
-
|
|
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');
|
|
3843
3858
|
}
|
|
3859
|
+
doVisible(this, key, value, oldValue);
|
|
3844
3860
|
}
|
|
3845
3861
|
}));
|
|
3846
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
|
+
}
|
|
3847
3870
|
function sortType(defaultValue) {
|
|
3848
3871
|
return decorateLeafAttr(defaultValue, (key) => attr({
|
|
3849
3872
|
set(value) {
|
|
@@ -3927,7 +3950,16 @@ function defineDataProcessor(target, key, defaultValue) {
|
|
|
3927
3950
|
if (defaultValue === undefined) {
|
|
3928
3951
|
property.get = function () { return this[computedKey]; };
|
|
3929
3952
|
}
|
|
3930
|
-
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') {
|
|
3931
3963
|
property.get = function () {
|
|
3932
3964
|
const v = this[computedKey];
|
|
3933
3965
|
if (v === undefined) {
|
|
@@ -4451,15 +4483,16 @@ class LeafLayout {
|
|
|
4451
4483
|
}
|
|
4452
4484
|
getLayoutBounds(type, relative = 'world', unscale) {
|
|
4453
4485
|
const { leaf } = this;
|
|
4454
|
-
let point, matrix, bounds = this.getInnerBounds(type);
|
|
4486
|
+
let point, matrix, layoutBounds, bounds = this.getInnerBounds(type);
|
|
4455
4487
|
switch (relative) {
|
|
4456
4488
|
case 'world':
|
|
4457
4489
|
point = leaf.getWorldPoint(bounds);
|
|
4458
4490
|
matrix = leaf.__world;
|
|
4459
4491
|
break;
|
|
4460
4492
|
case 'local':
|
|
4493
|
+
const { scaleX, scaleY, rotation, skewX, skewY } = leaf.__;
|
|
4494
|
+
layoutBounds = { scaleX, scaleY, rotation, skewX, skewY };
|
|
4461
4495
|
point = leaf.getLocalPointByInner(bounds);
|
|
4462
|
-
matrix = leaf.__localMatrix;
|
|
4463
4496
|
break;
|
|
4464
4497
|
case 'inner':
|
|
4465
4498
|
point = bounds;
|
|
@@ -4471,7 +4504,8 @@ class LeafLayout {
|
|
|
4471
4504
|
point = leaf.getWorldPoint(bounds, relative);
|
|
4472
4505
|
matrix = getRelativeWorld$1(leaf, relative, true);
|
|
4473
4506
|
}
|
|
4474
|
-
|
|
4507
|
+
if (!layoutBounds)
|
|
4508
|
+
layoutBounds = MatrixHelper.getLayout(matrix);
|
|
4475
4509
|
copy$6(layoutBounds, bounds);
|
|
4476
4510
|
PointHelper.copy(layoutBounds, point);
|
|
4477
4511
|
if (unscale) {
|
|
@@ -4594,144 +4628,6 @@ class LeafLayout {
|
|
|
4594
4628
|
destroy() { }
|
|
4595
4629
|
}
|
|
4596
4630
|
|
|
4597
|
-
const empty = {};
|
|
4598
|
-
const LeafEventer = {
|
|
4599
|
-
on(type, listener, options) {
|
|
4600
|
-
let capture, once;
|
|
4601
|
-
if (options) {
|
|
4602
|
-
if (options === 'once') {
|
|
4603
|
-
once = true;
|
|
4604
|
-
}
|
|
4605
|
-
else if (typeof options === 'boolean') {
|
|
4606
|
-
capture = options;
|
|
4607
|
-
}
|
|
4608
|
-
else {
|
|
4609
|
-
capture = options.capture;
|
|
4610
|
-
once = options.once;
|
|
4611
|
-
}
|
|
4612
|
-
}
|
|
4613
|
-
let events;
|
|
4614
|
-
const map = __getListenerMap(this, capture, true);
|
|
4615
|
-
const typeList = typeof type === 'string' ? type.split(' ') : type;
|
|
4616
|
-
const item = once ? { listener, once } : { listener };
|
|
4617
|
-
typeList.forEach(type => {
|
|
4618
|
-
if (type) {
|
|
4619
|
-
events = map[type];
|
|
4620
|
-
if (events) {
|
|
4621
|
-
if (events.findIndex(item => item.listener === listener) === -1)
|
|
4622
|
-
events.push(item);
|
|
4623
|
-
}
|
|
4624
|
-
else {
|
|
4625
|
-
map[type] = [item];
|
|
4626
|
-
}
|
|
4627
|
-
}
|
|
4628
|
-
});
|
|
4629
|
-
},
|
|
4630
|
-
off(type, listener, options) {
|
|
4631
|
-
if (type) {
|
|
4632
|
-
const typeList = typeof type === 'string' ? type.split(' ') : type;
|
|
4633
|
-
if (listener) {
|
|
4634
|
-
let capture;
|
|
4635
|
-
if (options)
|
|
4636
|
-
capture = typeof options === 'boolean' ? options : (options === 'once' ? false : options.capture);
|
|
4637
|
-
let events, index;
|
|
4638
|
-
const map = __getListenerMap(this, capture);
|
|
4639
|
-
typeList.forEach(type => {
|
|
4640
|
-
if (type) {
|
|
4641
|
-
events = map[type];
|
|
4642
|
-
if (events) {
|
|
4643
|
-
index = events.findIndex(item => item.listener === listener);
|
|
4644
|
-
if (index > -1)
|
|
4645
|
-
events.splice(index, 1);
|
|
4646
|
-
if (!events.length)
|
|
4647
|
-
delete map[type];
|
|
4648
|
-
}
|
|
4649
|
-
}
|
|
4650
|
-
});
|
|
4651
|
-
}
|
|
4652
|
-
else {
|
|
4653
|
-
const { __bubbleMap: b, __captureMap: c } = this;
|
|
4654
|
-
typeList.forEach(type => {
|
|
4655
|
-
if (b)
|
|
4656
|
-
delete b[type];
|
|
4657
|
-
if (c)
|
|
4658
|
-
delete c[type];
|
|
4659
|
-
});
|
|
4660
|
-
}
|
|
4661
|
-
}
|
|
4662
|
-
else {
|
|
4663
|
-
this.__bubbleMap = this.__captureMap = undefined;
|
|
4664
|
-
}
|
|
4665
|
-
},
|
|
4666
|
-
on_(type, listener, bind, options) {
|
|
4667
|
-
if (bind)
|
|
4668
|
-
listener = listener.bind(bind);
|
|
4669
|
-
this.on(type, listener, options);
|
|
4670
|
-
return { type, current: this, listener, options };
|
|
4671
|
-
},
|
|
4672
|
-
off_(id) {
|
|
4673
|
-
if (!id)
|
|
4674
|
-
return;
|
|
4675
|
-
const list = id instanceof Array ? id : [id];
|
|
4676
|
-
list.forEach(item => item.current.off(item.type, item.listener, item.options));
|
|
4677
|
-
list.length = 0;
|
|
4678
|
-
},
|
|
4679
|
-
once(type, listener, capture) {
|
|
4680
|
-
this.on(type, listener, { once: true, capture });
|
|
4681
|
-
},
|
|
4682
|
-
emit(type, event, capture) {
|
|
4683
|
-
if (!event && EventCreator.has(type))
|
|
4684
|
-
event = EventCreator.get(type, { type, target: this, current: this });
|
|
4685
|
-
const map = __getListenerMap(this, capture);
|
|
4686
|
-
const list = map[type];
|
|
4687
|
-
if (list) {
|
|
4688
|
-
let item;
|
|
4689
|
-
for (let i = 0, len = list.length; i < len; i++) {
|
|
4690
|
-
item = list[i];
|
|
4691
|
-
item.listener(event);
|
|
4692
|
-
if (item.once) {
|
|
4693
|
-
this.off(type, item.listener, capture);
|
|
4694
|
-
i--, len--;
|
|
4695
|
-
}
|
|
4696
|
-
if (event && event.isStopNow)
|
|
4697
|
-
break;
|
|
4698
|
-
}
|
|
4699
|
-
}
|
|
4700
|
-
this.syncEventer && this.syncEventer.emitEvent(event, capture);
|
|
4701
|
-
},
|
|
4702
|
-
emitEvent(event, capture) {
|
|
4703
|
-
event.current = this;
|
|
4704
|
-
this.emit(event.type, event, capture);
|
|
4705
|
-
},
|
|
4706
|
-
hasEvent(type, capture) {
|
|
4707
|
-
if (this.syncEventer && this.syncEventer.hasEvent(type, capture))
|
|
4708
|
-
return true;
|
|
4709
|
-
const { __bubbleMap: b, __captureMap: c } = this;
|
|
4710
|
-
const hasB = b && b[type], hasC = c && c[type];
|
|
4711
|
-
return !!(capture === undefined ? (hasB || hasC) : (capture ? hasC : hasB));
|
|
4712
|
-
},
|
|
4713
|
-
};
|
|
4714
|
-
function __getListenerMap(eventer, capture, create) {
|
|
4715
|
-
if (capture) {
|
|
4716
|
-
const { __captureMap: c } = eventer;
|
|
4717
|
-
if (c) {
|
|
4718
|
-
return c;
|
|
4719
|
-
}
|
|
4720
|
-
else {
|
|
4721
|
-
return create ? eventer.__captureMap = {} : empty;
|
|
4722
|
-
}
|
|
4723
|
-
}
|
|
4724
|
-
else {
|
|
4725
|
-
const { __bubbleMap: b } = eventer;
|
|
4726
|
-
if (b) {
|
|
4727
|
-
return b;
|
|
4728
|
-
}
|
|
4729
|
-
else {
|
|
4730
|
-
return create ? eventer.__bubbleMap = {} : empty;
|
|
4731
|
-
}
|
|
4732
|
-
}
|
|
4733
|
-
}
|
|
4734
|
-
|
|
4735
4631
|
class Event {
|
|
4736
4632
|
constructor(type, target) {
|
|
4737
4633
|
this.bubbles = false;
|
|
@@ -4766,7 +4662,10 @@ class ChildEvent extends Event {
|
|
|
4766
4662
|
}
|
|
4767
4663
|
ChildEvent.ADD = 'child.add';
|
|
4768
4664
|
ChildEvent.REMOVE = 'child.remove';
|
|
4769
|
-
ChildEvent.
|
|
4665
|
+
ChildEvent.CREATED = 'created';
|
|
4666
|
+
ChildEvent.MOUNTED = 'mounted';
|
|
4667
|
+
ChildEvent.UNMOUNTED = 'unmounted';
|
|
4668
|
+
ChildEvent.DESTROY = 'destroy';
|
|
4770
4669
|
|
|
4771
4670
|
class PropertyEvent extends Event {
|
|
4772
4671
|
constructor(type, target, attrName, oldValue, newValue) {
|
|
@@ -4844,10 +4743,6 @@ LayoutEvent.AFTER = 'layout.after';
|
|
|
4844
4743
|
LayoutEvent.AGAIN = 'layout.again';
|
|
4845
4744
|
LayoutEvent.END = 'layout.end';
|
|
4846
4745
|
|
|
4847
|
-
class AnimateEvent extends Event {
|
|
4848
|
-
}
|
|
4849
|
-
AnimateEvent.FRAME = 'animate.frame';
|
|
4850
|
-
|
|
4851
4746
|
class RenderEvent extends Event {
|
|
4852
4747
|
constructor(type, times, bounds, options) {
|
|
4853
4748
|
super(type);
|
|
@@ -4880,6 +4775,157 @@ LeaferEvent.STOP = 'leafer.stop';
|
|
|
4880
4775
|
LeaferEvent.RESTART = 'leafer.restart';
|
|
4881
4776
|
LeaferEvent.END = 'leafer.end';
|
|
4882
4777
|
|
|
4778
|
+
const empty = {};
|
|
4779
|
+
class Eventer {
|
|
4780
|
+
set event(map) { this.on(map); }
|
|
4781
|
+
on(type, listener, options) {
|
|
4782
|
+
if (!listener) {
|
|
4783
|
+
let event, map = type;
|
|
4784
|
+
for (let key in map)
|
|
4785
|
+
event = map[key], event instanceof Array ? this.on(key, event[0], event[1]) : this.on(key, event);
|
|
4786
|
+
return;
|
|
4787
|
+
}
|
|
4788
|
+
let capture, once;
|
|
4789
|
+
if (options) {
|
|
4790
|
+
if (options === 'once') {
|
|
4791
|
+
once = true;
|
|
4792
|
+
}
|
|
4793
|
+
else if (typeof options === 'boolean') {
|
|
4794
|
+
capture = options;
|
|
4795
|
+
}
|
|
4796
|
+
else {
|
|
4797
|
+
capture = options.capture;
|
|
4798
|
+
once = options.once;
|
|
4799
|
+
}
|
|
4800
|
+
}
|
|
4801
|
+
let events;
|
|
4802
|
+
const map = __getListenerMap(this, capture, true);
|
|
4803
|
+
const typeList = typeof type === 'string' ? type.split(' ') : type;
|
|
4804
|
+
const item = once ? { listener, once } : { listener };
|
|
4805
|
+
typeList.forEach(type => {
|
|
4806
|
+
if (type) {
|
|
4807
|
+
events = map[type];
|
|
4808
|
+
if (events) {
|
|
4809
|
+
if (events.findIndex(item => item.listener === listener) === -1)
|
|
4810
|
+
events.push(item);
|
|
4811
|
+
}
|
|
4812
|
+
else {
|
|
4813
|
+
map[type] = [item];
|
|
4814
|
+
}
|
|
4815
|
+
}
|
|
4816
|
+
});
|
|
4817
|
+
}
|
|
4818
|
+
off(type, listener, options) {
|
|
4819
|
+
if (type) {
|
|
4820
|
+
const typeList = typeof type === 'string' ? type.split(' ') : type;
|
|
4821
|
+
if (listener) {
|
|
4822
|
+
let capture;
|
|
4823
|
+
if (options)
|
|
4824
|
+
capture = typeof options === 'boolean' ? options : (options === 'once' ? false : options.capture);
|
|
4825
|
+
let events, index;
|
|
4826
|
+
const map = __getListenerMap(this, capture);
|
|
4827
|
+
typeList.forEach(type => {
|
|
4828
|
+
if (type) {
|
|
4829
|
+
events = map[type];
|
|
4830
|
+
if (events) {
|
|
4831
|
+
index = events.findIndex(item => item.listener === listener);
|
|
4832
|
+
if (index > -1)
|
|
4833
|
+
events.splice(index, 1);
|
|
4834
|
+
if (!events.length)
|
|
4835
|
+
delete map[type];
|
|
4836
|
+
}
|
|
4837
|
+
}
|
|
4838
|
+
});
|
|
4839
|
+
}
|
|
4840
|
+
else {
|
|
4841
|
+
const { __bubbleMap: b, __captureMap: c } = this;
|
|
4842
|
+
typeList.forEach(type => {
|
|
4843
|
+
if (b)
|
|
4844
|
+
delete b[type];
|
|
4845
|
+
if (c)
|
|
4846
|
+
delete c[type];
|
|
4847
|
+
});
|
|
4848
|
+
}
|
|
4849
|
+
}
|
|
4850
|
+
else {
|
|
4851
|
+
this.__bubbleMap = this.__captureMap = undefined;
|
|
4852
|
+
}
|
|
4853
|
+
}
|
|
4854
|
+
on_(type, listener, bind, options) {
|
|
4855
|
+
if (bind)
|
|
4856
|
+
listener = listener.bind(bind);
|
|
4857
|
+
this.on(type, listener, options);
|
|
4858
|
+
return { type, current: this, listener, options };
|
|
4859
|
+
}
|
|
4860
|
+
off_(id) {
|
|
4861
|
+
if (!id)
|
|
4862
|
+
return;
|
|
4863
|
+
const list = id instanceof Array ? id : [id];
|
|
4864
|
+
list.forEach(item => item.current.off(item.type, item.listener, item.options));
|
|
4865
|
+
list.length = 0;
|
|
4866
|
+
}
|
|
4867
|
+
once(type, listener, capture) {
|
|
4868
|
+
this.on(type, listener, { once: true, capture });
|
|
4869
|
+
}
|
|
4870
|
+
emit(type, event, capture) {
|
|
4871
|
+
if (!event && EventCreator.has(type))
|
|
4872
|
+
event = EventCreator.get(type, { type, target: this, current: this });
|
|
4873
|
+
const map = __getListenerMap(this, capture);
|
|
4874
|
+
const list = map[type];
|
|
4875
|
+
if (list) {
|
|
4876
|
+
let item;
|
|
4877
|
+
for (let i = 0, len = list.length; i < len; i++) {
|
|
4878
|
+
item = list[i];
|
|
4879
|
+
item.listener(event);
|
|
4880
|
+
if (item.once) {
|
|
4881
|
+
this.off(type, item.listener, capture);
|
|
4882
|
+
i--, len--;
|
|
4883
|
+
}
|
|
4884
|
+
if (event && event.isStopNow)
|
|
4885
|
+
break;
|
|
4886
|
+
}
|
|
4887
|
+
}
|
|
4888
|
+
this.syncEventer && this.syncEventer.emitEvent(event, capture);
|
|
4889
|
+
}
|
|
4890
|
+
emitEvent(event, capture) {
|
|
4891
|
+
event.current = this;
|
|
4892
|
+
this.emit(event.type, event, capture);
|
|
4893
|
+
}
|
|
4894
|
+
hasEvent(type, capture) {
|
|
4895
|
+
if (this.syncEventer && this.syncEventer.hasEvent(type, capture))
|
|
4896
|
+
return true;
|
|
4897
|
+
const { __bubbleMap: b, __captureMap: c } = this;
|
|
4898
|
+
const hasB = b && b[type], hasC = c && c[type];
|
|
4899
|
+
return !!(capture === undefined ? (hasB || hasC) : (capture ? hasC : hasB));
|
|
4900
|
+
}
|
|
4901
|
+
destroy() {
|
|
4902
|
+
this.__captureMap = this.__bubbleMap = this.syncEventer = null;
|
|
4903
|
+
}
|
|
4904
|
+
}
|
|
4905
|
+
function __getListenerMap(eventer, capture, create) {
|
|
4906
|
+
if (capture) {
|
|
4907
|
+
const { __captureMap: c } = eventer;
|
|
4908
|
+
if (c) {
|
|
4909
|
+
return c;
|
|
4910
|
+
}
|
|
4911
|
+
else {
|
|
4912
|
+
return create ? eventer.__captureMap = {} : empty;
|
|
4913
|
+
}
|
|
4914
|
+
}
|
|
4915
|
+
else {
|
|
4916
|
+
const { __bubbleMap: b } = eventer;
|
|
4917
|
+
if (b) {
|
|
4918
|
+
return b;
|
|
4919
|
+
}
|
|
4920
|
+
else {
|
|
4921
|
+
return create ? eventer.__bubbleMap = {} : empty;
|
|
4922
|
+
}
|
|
4923
|
+
}
|
|
4924
|
+
}
|
|
4925
|
+
|
|
4926
|
+
const { on, on_, off, off_, once, emit: emit$2, emitEvent: emitEvent$1, hasEvent, destroy } = Eventer.prototype;
|
|
4927
|
+
const LeafEventer = { on, on_, off, off_, once, emit: emit$2, emitEvent: emitEvent$1, hasEvent, destroyEventer: destroy };
|
|
4928
|
+
|
|
4883
4929
|
const { isFinite } = Number;
|
|
4884
4930
|
const debug$7 = Debug.get('setAttr');
|
|
4885
4931
|
const LeafDataProxy = {
|
|
@@ -4891,9 +4937,7 @@ const LeafDataProxy = {
|
|
|
4891
4937
|
newValue = undefined;
|
|
4892
4938
|
}
|
|
4893
4939
|
if (typeof newValue === 'object' || oldValue !== newValue) {
|
|
4894
|
-
this.
|
|
4895
|
-
if (this.__proxyData)
|
|
4896
|
-
this.setProxyAttr(name, newValue);
|
|
4940
|
+
this.__realSetAttr(name, newValue);
|
|
4897
4941
|
const { CHANGE } = PropertyEvent;
|
|
4898
4942
|
const event = new PropertyEvent(CHANGE, this, name, oldValue, newValue);
|
|
4899
4943
|
if (this.isLeafer) {
|
|
@@ -4911,12 +4955,18 @@ const LeafDataProxy = {
|
|
|
4911
4955
|
}
|
|
4912
4956
|
}
|
|
4913
4957
|
else {
|
|
4914
|
-
this.
|
|
4915
|
-
if (this.__proxyData)
|
|
4916
|
-
this.setProxyAttr(name, newValue);
|
|
4958
|
+
this.__realSetAttr(name, newValue);
|
|
4917
4959
|
return true;
|
|
4918
4960
|
}
|
|
4919
4961
|
},
|
|
4962
|
+
__realSetAttr(name, newValue) {
|
|
4963
|
+
const data = this.__;
|
|
4964
|
+
data[name] = newValue;
|
|
4965
|
+
if (this.__proxyData)
|
|
4966
|
+
this.setProxyAttr(name, newValue);
|
|
4967
|
+
if (data.normalStyle)
|
|
4968
|
+
this.lockNormalStyle || data.normalStyle[name] === undefined || (data.normalStyle[name] = newValue);
|
|
4969
|
+
},
|
|
4920
4970
|
__getAttr(name) {
|
|
4921
4971
|
if (this.__proxyData)
|
|
4922
4972
|
return this.getProxyAttr(name);
|
|
@@ -5019,6 +5069,8 @@ const LeafBounds = {
|
|
|
5019
5069
|
layout.boundsChanged = false;
|
|
5020
5070
|
},
|
|
5021
5071
|
__updateLocalBoxBounds() {
|
|
5072
|
+
if (this.__hasMotionPath)
|
|
5073
|
+
this.__updateMotionPath();
|
|
5022
5074
|
if (this.__hasAutoLayout)
|
|
5023
5075
|
this.__updateAutoLayout();
|
|
5024
5076
|
toOuterOf$1(this.__layout.boxBounds, this.__local, this.__local);
|
|
@@ -5171,7 +5223,7 @@ const BranchRender = {
|
|
|
5171
5223
|
const { LEAF, create } = IncrementId;
|
|
5172
5224
|
const { toInnerPoint, toOuterPoint, multiplyParent } = MatrixHelper;
|
|
5173
5225
|
const { toOuterOf } = BoundsHelper;
|
|
5174
|
-
const { copy: copy$4 } = PointHelper;
|
|
5226
|
+
const { copy: copy$4, move: move$1 } = PointHelper;
|
|
5175
5227
|
const { moveLocal, zoomOfLocal, rotateOfLocal, skewOfLocal, moveWorld, zoomOfWorld, rotateOfWorld, skewOfWorld, transform, transformWorld, setTransform, getFlipTransform, getLocalOrigin, getRelativeWorld, drop } = LeafHelper;
|
|
5176
5228
|
let Leaf = class Leaf {
|
|
5177
5229
|
get tag() { return this.__tag; }
|
|
@@ -5198,13 +5250,16 @@ let Leaf = class Leaf {
|
|
|
5198
5250
|
get __ignoreHitWorld() { return (this.__hasMask || this.__hasEraser) && this.__.hitChildren; }
|
|
5199
5251
|
get __inLazyBounds() { const { leafer } = this; return leafer && leafer.created && leafer.lazyBounds.hit(this.__world); }
|
|
5200
5252
|
get pathInputed() { return this.__.__pathInputed; }
|
|
5201
|
-
set event(map) {
|
|
5202
|
-
event = map[key], event instanceof Array ? this.on(key, event[0], event[1]) : this.on(key, event); }
|
|
5253
|
+
set event(map) { this.on(map); }
|
|
5203
5254
|
constructor(data) {
|
|
5204
5255
|
this.innerId = create(LEAF);
|
|
5205
5256
|
this.reset(data);
|
|
5257
|
+
if (this.__bubbleMap)
|
|
5258
|
+
this.__emitLifeEvent(ChildEvent.CREATED);
|
|
5206
5259
|
}
|
|
5207
5260
|
reset(data) {
|
|
5261
|
+
if (this.leafer)
|
|
5262
|
+
this.leafer.forceRender(this.__world);
|
|
5208
5263
|
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 };
|
|
5209
5264
|
if (data !== null)
|
|
5210
5265
|
this.__local = { a: 1, b: 0, c: 0, d: 1, e: 0, f: 0, x: 0, y: 0, width: 0, height: 0 };
|
|
@@ -5226,12 +5281,12 @@ let Leaf = class Leaf {
|
|
|
5226
5281
|
waitParent(item, bind) {
|
|
5227
5282
|
if (bind)
|
|
5228
5283
|
item = item.bind(bind);
|
|
5229
|
-
this.parent ? item() :
|
|
5284
|
+
this.parent ? item() : this.on(ChildEvent.ADD, item, 'once');
|
|
5230
5285
|
}
|
|
5231
5286
|
waitLeafer(item, bind) {
|
|
5232
5287
|
if (bind)
|
|
5233
5288
|
item = item.bind(bind);
|
|
5234
|
-
this.leafer ? item() :
|
|
5289
|
+
this.leafer ? item() : this.on(ChildEvent.MOUNTED, item, 'once');
|
|
5235
5290
|
}
|
|
5236
5291
|
nextRender(item, bind, off) {
|
|
5237
5292
|
this.leafer ? this.leafer.nextRender(item, bind, off) : this.waitLeafer(() => this.leafer.nextRender(item, bind, off));
|
|
@@ -5240,18 +5295,21 @@ let Leaf = class Leaf {
|
|
|
5240
5295
|
this.nextRender(item, null, 'off');
|
|
5241
5296
|
}
|
|
5242
5297
|
__bindLeafer(leafer) {
|
|
5243
|
-
if (this.isLeafer)
|
|
5244
|
-
|
|
5245
|
-
leafer = this;
|
|
5246
|
-
}
|
|
5298
|
+
if (this.isLeafer && leafer !== null)
|
|
5299
|
+
leafer = this;
|
|
5247
5300
|
if (this.leafer && !leafer)
|
|
5248
5301
|
this.leafer.leafs--;
|
|
5249
5302
|
this.leafer = leafer;
|
|
5250
5303
|
if (leafer) {
|
|
5251
5304
|
leafer.leafs++;
|
|
5252
5305
|
this.__level = this.parent ? this.parent.__level + 1 : 1;
|
|
5253
|
-
if (this.
|
|
5254
|
-
|
|
5306
|
+
if (this.animation)
|
|
5307
|
+
this.__runAnimation('in');
|
|
5308
|
+
if (this.__bubbleMap)
|
|
5309
|
+
this.__emitLifeEvent(ChildEvent.MOUNTED);
|
|
5310
|
+
}
|
|
5311
|
+
else {
|
|
5312
|
+
this.__emitLifeEvent(ChildEvent.UNMOUNTED);
|
|
5255
5313
|
}
|
|
5256
5314
|
if (this.isBranch) {
|
|
5257
5315
|
const { children } = this;
|
|
@@ -5260,7 +5318,7 @@ let Leaf = class Leaf {
|
|
|
5260
5318
|
}
|
|
5261
5319
|
}
|
|
5262
5320
|
}
|
|
5263
|
-
set(_data) { }
|
|
5321
|
+
set(_data, _isTemp) { }
|
|
5264
5322
|
get(_name) { return undefined; }
|
|
5265
5323
|
setAttr(name, value) { this[name] = value; }
|
|
5266
5324
|
getAttr(name) { return this[name]; }
|
|
@@ -5285,6 +5343,7 @@ let Leaf = class Leaf {
|
|
|
5285
5343
|
findOne(_condition, _options) { return undefined; }
|
|
5286
5344
|
findId(_id) { return undefined; }
|
|
5287
5345
|
focus(_value) { }
|
|
5346
|
+
updateState() { }
|
|
5288
5347
|
updateLayout() {
|
|
5289
5348
|
this.__layout.update();
|
|
5290
5349
|
}
|
|
@@ -5392,11 +5451,24 @@ let Leaf = class Leaf {
|
|
|
5392
5451
|
if (relative)
|
|
5393
5452
|
relative.worldToInner(to ? to : inner, null, distance);
|
|
5394
5453
|
}
|
|
5454
|
+
getBoxPoint(world, relative, distance, change) {
|
|
5455
|
+
return this.getBoxPointByInner(this.getInnerPoint(world, relative, distance, change), null, null, true);
|
|
5456
|
+
}
|
|
5457
|
+
getBoxPointByInner(inner, _relative, _distance, change) {
|
|
5458
|
+
const point = change ? inner : Object.assign({}, inner), { x, y } = this.boxBounds;
|
|
5459
|
+
move$1(point, -x, -y);
|
|
5460
|
+
return point;
|
|
5461
|
+
}
|
|
5395
5462
|
getInnerPoint(world, relative, distance, change) {
|
|
5396
5463
|
const point = change ? world : {};
|
|
5397
5464
|
this.worldToInner(world, point, distance, relative);
|
|
5398
5465
|
return point;
|
|
5399
5466
|
}
|
|
5467
|
+
getInnerPointByBox(box, _relative, _distance, change) {
|
|
5468
|
+
const point = change ? box : Object.assign({}, box), { x, y } = this.boxBounds;
|
|
5469
|
+
move$1(point, x, y);
|
|
5470
|
+
return point;
|
|
5471
|
+
}
|
|
5400
5472
|
getInnerPointByLocal(local, _relative, distance, change) {
|
|
5401
5473
|
return this.getInnerPoint(local, this.parent, distance, change);
|
|
5402
5474
|
}
|
|
@@ -5408,20 +5480,23 @@ let Leaf = class Leaf {
|
|
|
5408
5480
|
getLocalPointByInner(inner, _relative, distance, change) {
|
|
5409
5481
|
return this.getWorldPoint(inner, this.parent, distance, change);
|
|
5410
5482
|
}
|
|
5483
|
+
getPagePoint(world, relative, distance, change) {
|
|
5484
|
+
const layer = this.leafer ? this.leafer.zoomLayer : this;
|
|
5485
|
+
return layer.getInnerPoint(world, relative, distance, change);
|
|
5486
|
+
}
|
|
5411
5487
|
getWorldPoint(inner, relative, distance, change) {
|
|
5412
5488
|
const point = change ? inner : {};
|
|
5413
5489
|
this.innerToWorld(inner, point, distance, relative);
|
|
5414
5490
|
return point;
|
|
5415
5491
|
}
|
|
5492
|
+
getWorldPointByBox(box, relative, distance, change) {
|
|
5493
|
+
return this.getWorldPoint(this.getInnerPointByBox(box, null, null, change), relative, distance, true);
|
|
5494
|
+
}
|
|
5416
5495
|
getWorldPointByLocal(local, relative, distance, change) {
|
|
5417
5496
|
const point = change ? local : {};
|
|
5418
5497
|
this.localToWorld(local, point, distance, relative);
|
|
5419
5498
|
return point;
|
|
5420
5499
|
}
|
|
5421
|
-
getPagePoint(world, relative, distance, change) {
|
|
5422
|
-
const layer = this.leafer ? this.leafer.zoomLayer : this;
|
|
5423
|
-
return layer.getInnerPoint(world, relative, distance, change);
|
|
5424
|
-
}
|
|
5425
5500
|
getWorldPointByPage(page, relative, distance, change) {
|
|
5426
5501
|
const layer = this.leafer ? this.leafer.zoomLayer : this;
|
|
5427
5502
|
return layer.getWorldPoint(page, relative, distance, change);
|
|
@@ -5490,6 +5565,17 @@ let Leaf = class Leaf {
|
|
|
5490
5565
|
__drawRenderPath(_canvas) { }
|
|
5491
5566
|
__updatePath() { }
|
|
5492
5567
|
__updateRenderPath() { }
|
|
5568
|
+
getMotionPathData() {
|
|
5569
|
+
return needPlugin('path');
|
|
5570
|
+
}
|
|
5571
|
+
getMotionPoint(_motionDistance) {
|
|
5572
|
+
return needPlugin('path');
|
|
5573
|
+
}
|
|
5574
|
+
getMotionTotal() {
|
|
5575
|
+
return 0;
|
|
5576
|
+
}
|
|
5577
|
+
__updateMotionPath() { }
|
|
5578
|
+
__runAnimation(_type, _complete) { }
|
|
5493
5579
|
__updateSortChildren() { }
|
|
5494
5580
|
add(_child, _index) { }
|
|
5495
5581
|
remove(_child, destroy) {
|
|
@@ -5515,6 +5601,10 @@ let Leaf = class Leaf {
|
|
|
5515
5601
|
fn = boundsType;
|
|
5516
5602
|
fn(defaultValue)(this.prototype, attrName);
|
|
5517
5603
|
}
|
|
5604
|
+
__emitLifeEvent(type) {
|
|
5605
|
+
if (this.hasEvent(type))
|
|
5606
|
+
this.emitEvent(new ChildEvent(type, this, this.parent));
|
|
5607
|
+
}
|
|
5518
5608
|
destroy() {
|
|
5519
5609
|
if (!this.destroyed) {
|
|
5520
5610
|
const { parent } = this;
|
|
@@ -5522,11 +5612,10 @@ let Leaf = class Leaf {
|
|
|
5522
5612
|
this.remove();
|
|
5523
5613
|
if (this.children)
|
|
5524
5614
|
this.removeAll(true);
|
|
5525
|
-
|
|
5526
|
-
this.emitEvent(new ChildEvent(ChildEvent.DESTROY, this, parent));
|
|
5615
|
+
this.__emitLifeEvent(ChildEvent.DESTROY);
|
|
5527
5616
|
this.__.destroy();
|
|
5528
5617
|
this.__layout.destroy();
|
|
5529
|
-
this.
|
|
5618
|
+
this.destroyEventer();
|
|
5530
5619
|
this.destroyed = true;
|
|
5531
5620
|
}
|
|
5532
5621
|
}
|
|
@@ -5592,8 +5681,8 @@ let Branch = class Branch extends Leaf {
|
|
|
5592
5681
|
this.__.__childBranchNumber = (this.__.__childBranchNumber || 0) + 1;
|
|
5593
5682
|
child.__layout.boxChanged || child.__layout.boxChange();
|
|
5594
5683
|
child.__layout.matrixChanged || child.__layout.matrixChange();
|
|
5595
|
-
if (child.
|
|
5596
|
-
|
|
5684
|
+
if (child.__bubbleMap)
|
|
5685
|
+
child.__emitLifeEvent(ChildEvent.ADD);
|
|
5597
5686
|
if (this.leafer) {
|
|
5598
5687
|
child.__bindLeafer(this.leafer);
|
|
5599
5688
|
if (this.leafer.created)
|
|
@@ -5606,16 +5695,10 @@ let Branch = class Branch extends Leaf {
|
|
|
5606
5695
|
}
|
|
5607
5696
|
remove(child, destroy) {
|
|
5608
5697
|
if (child) {
|
|
5609
|
-
|
|
5610
|
-
|
|
5611
|
-
|
|
5612
|
-
|
|
5613
|
-
this.__.__childBranchNumber = (this.__.__childBranchNumber || 1) - 1;
|
|
5614
|
-
this.__preRemove();
|
|
5615
|
-
this.__realRemoveChild(child);
|
|
5616
|
-
if (destroy)
|
|
5617
|
-
child.destroy();
|
|
5618
|
-
}
|
|
5698
|
+
if (child.animationOut)
|
|
5699
|
+
child.__runAnimation('out', () => this.__remove(child, destroy));
|
|
5700
|
+
else
|
|
5701
|
+
this.__remove(child, destroy);
|
|
5619
5702
|
}
|
|
5620
5703
|
else if (child === undefined) {
|
|
5621
5704
|
super.remove(null, destroy);
|
|
@@ -5637,6 +5720,18 @@ let Branch = class Branch extends Leaf {
|
|
|
5637
5720
|
clear() {
|
|
5638
5721
|
this.removeAll(true);
|
|
5639
5722
|
}
|
|
5723
|
+
__remove(child, destroy) {
|
|
5724
|
+
const index = this.children.indexOf(child);
|
|
5725
|
+
if (index > -1) {
|
|
5726
|
+
this.children.splice(index, 1);
|
|
5727
|
+
if (child.isBranch)
|
|
5728
|
+
this.__.__childBranchNumber = (this.__.__childBranchNumber || 1) - 1;
|
|
5729
|
+
this.__preRemove();
|
|
5730
|
+
this.__realRemoveChild(child);
|
|
5731
|
+
if (destroy)
|
|
5732
|
+
child.destroy();
|
|
5733
|
+
}
|
|
5734
|
+
}
|
|
5640
5735
|
__preRemove() {
|
|
5641
5736
|
if (this.__hasMask)
|
|
5642
5737
|
this.__updateMask();
|
|
@@ -5646,6 +5741,7 @@ let Branch = class Branch extends Leaf {
|
|
|
5646
5741
|
this.__layout.affectChildrenSort && this.__layout.childrenSortChange();
|
|
5647
5742
|
}
|
|
5648
5743
|
__realRemoveChild(child) {
|
|
5744
|
+
child.__emitLifeEvent(ChildEvent.REMOVE);
|
|
5649
5745
|
child.parent = null;
|
|
5650
5746
|
if (this.leafer) {
|
|
5651
5747
|
child.__bindLeafer(null);
|
|
@@ -5658,8 +5754,6 @@ let Branch = class Branch extends Leaf {
|
|
|
5658
5754
|
}
|
|
5659
5755
|
__emitChildEvent(type, child) {
|
|
5660
5756
|
const event = new ChildEvent(type, child, this);
|
|
5661
|
-
if (child.hasEvent(type))
|
|
5662
|
-
child.emitEvent(event);
|
|
5663
5757
|
if (this.hasEvent(type) && !this.isLeafer)
|
|
5664
5758
|
this.emitEvent(event);
|
|
5665
5759
|
this.leafer.emitEvent(event);
|
|
@@ -5822,8 +5916,7 @@ class LeafLevelList {
|
|
|
5822
5916
|
}
|
|
5823
5917
|
}
|
|
5824
5918
|
|
|
5825
|
-
const version = "1.0.
|
|
5826
|
-
const inviteCode = {};
|
|
5919
|
+
const version = "1.0.4";
|
|
5827
5920
|
|
|
5828
5921
|
class LeaferCanvas extends LeaferCanvasBase {
|
|
5829
5922
|
get allowBackgroundColor() { return false; }
|
|
@@ -6187,9 +6280,13 @@ function updateBounds(boundsList) {
|
|
|
6187
6280
|
});
|
|
6188
6281
|
}
|
|
6189
6282
|
function updateChange(updateList) {
|
|
6283
|
+
let layout;
|
|
6190
6284
|
updateList.list.forEach(leaf => {
|
|
6191
|
-
|
|
6285
|
+
layout = leaf.__layout;
|
|
6286
|
+
if (layout.opacityChanged)
|
|
6192
6287
|
updateAllWorldOpacity(leaf);
|
|
6288
|
+
if (layout.stateStyleChanged)
|
|
6289
|
+
setTimeout(() => layout.stateStyleChanged && leaf.updateState());
|
|
6193
6290
|
leaf.__updateChange();
|
|
6194
6291
|
});
|
|
6195
6292
|
}
|
|
@@ -6555,7 +6652,6 @@ class Renderer {
|
|
|
6555
6652
|
Platform.requestRender(() => {
|
|
6556
6653
|
this.FPS = Math.min(60, Math.ceil(1000 / (Date.now() - startTime)));
|
|
6557
6654
|
if (this.running) {
|
|
6558
|
-
this.target.emit(AnimateEvent.FRAME);
|
|
6559
6655
|
if (this.changed && this.canvas.view)
|
|
6560
6656
|
this.render();
|
|
6561
6657
|
this.target.emit(RenderEvent.NEXT);
|
|
@@ -6900,36 +6996,6 @@ Object.assign(Creator, {
|
|
|
6900
6996
|
});
|
|
6901
6997
|
Platform.layout = Layouter.fullLayout;
|
|
6902
6998
|
|
|
6903
|
-
const TextConvert = {};
|
|
6904
|
-
const ColorConvert = {};
|
|
6905
|
-
const PathArrow = {};
|
|
6906
|
-
const Paint = {};
|
|
6907
|
-
const PaintImage = {};
|
|
6908
|
-
const PaintGradient = {};
|
|
6909
|
-
const Effect = {};
|
|
6910
|
-
const Export = {};
|
|
6911
|
-
const State = {};
|
|
6912
|
-
|
|
6913
|
-
function stateType(defaultValue) {
|
|
6914
|
-
return decorateLeafAttr(defaultValue, (key) => attr({
|
|
6915
|
-
set(value) {
|
|
6916
|
-
this.__setAttr(key, value);
|
|
6917
|
-
this.waitLeafer(() => { if (State.setStyle)
|
|
6918
|
-
State.setStyle(this, key + 'Style', value); });
|
|
6919
|
-
}
|
|
6920
|
-
}));
|
|
6921
|
-
}
|
|
6922
|
-
function arrowType(defaultValue) {
|
|
6923
|
-
return decorateLeafAttr(defaultValue, (key) => attr({
|
|
6924
|
-
set(value) {
|
|
6925
|
-
if (this.__setAttr(key, value)) {
|
|
6926
|
-
const data = this.__;
|
|
6927
|
-
data.__useArrow = data.startArrow !== 'none' || data.endArrow !== 'none';
|
|
6928
|
-
doStrokeType(this);
|
|
6929
|
-
}
|
|
6930
|
-
}
|
|
6931
|
-
}));
|
|
6932
|
-
}
|
|
6933
6999
|
function effectType(defaultValue) {
|
|
6934
7000
|
return decorateLeafAttr(defaultValue, (key) => attr({
|
|
6935
7001
|
set(value) {
|
|
@@ -6964,10 +7030,33 @@ function zoomLayerType() {
|
|
|
6964
7030
|
};
|
|
6965
7031
|
}
|
|
6966
7032
|
|
|
7033
|
+
const TextConvert = {};
|
|
7034
|
+
const ColorConvert = {};
|
|
7035
|
+
const PathArrow = {};
|
|
7036
|
+
const Paint = {};
|
|
7037
|
+
const PaintImage = {};
|
|
7038
|
+
const PaintGradient = {};
|
|
7039
|
+
const Effect = {};
|
|
7040
|
+
const Export = {};
|
|
7041
|
+
const State = {
|
|
7042
|
+
setStyleName(_leaf, _styleName, _value) { return needPlugin('state'); },
|
|
7043
|
+
set(_leaf, _stateName) { return needPlugin('state'); }
|
|
7044
|
+
};
|
|
7045
|
+
const Transition = {
|
|
7046
|
+
list: {},
|
|
7047
|
+
register(attrName, fn) {
|
|
7048
|
+
Transition.list[attrName] = fn;
|
|
7049
|
+
},
|
|
7050
|
+
get(attrName) {
|
|
7051
|
+
return Transition.list[attrName];
|
|
7052
|
+
}
|
|
7053
|
+
};
|
|
7054
|
+
|
|
6967
7055
|
const { parse } = PathConvert;
|
|
6968
7056
|
const emptyPaint = {};
|
|
6969
7057
|
const debug$4 = Debug.get('UIData');
|
|
6970
7058
|
class UIData extends LeafData {
|
|
7059
|
+
get scale() { const { scaleX, scaleY } = this; return scaleX !== scaleY ? { x: scaleX, y: scaleY } : scaleX; }
|
|
6971
7060
|
get __strokeWidth() {
|
|
6972
7061
|
const { strokeWidth, strokeWidthFixed } = this;
|
|
6973
7062
|
if (strokeWidthFixed) {
|
|
@@ -6986,9 +7075,10 @@ class UIData extends LeafData {
|
|
|
6986
7075
|
get __autoSide() { return !this._width || !this._height; }
|
|
6987
7076
|
get __autoSize() { return !this._width && !this._height; }
|
|
6988
7077
|
setVisible(value) {
|
|
6989
|
-
if (this.__leaf.leafer)
|
|
6990
|
-
this.__leaf.leafer.watcher.hasVisible = true;
|
|
6991
7078
|
this._visible = value;
|
|
7079
|
+
const { leafer } = this.__leaf;
|
|
7080
|
+
if (leafer)
|
|
7081
|
+
leafer.watcher.hasVisible = true;
|
|
6992
7082
|
}
|
|
6993
7083
|
setWidth(value) {
|
|
6994
7084
|
if (value < 0) {
|
|
@@ -7179,7 +7269,7 @@ class ImageData extends RectData {
|
|
|
7179
7269
|
__setImageFill(value) {
|
|
7180
7270
|
if (this.__leaf.image)
|
|
7181
7271
|
this.__leaf.image = null;
|
|
7182
|
-
this.fill = value ? { type: 'image', mode: '
|
|
7272
|
+
this.fill = value ? { type: 'image', mode: 'stretch', url: value } : undefined;
|
|
7183
7273
|
}
|
|
7184
7274
|
__getData() {
|
|
7185
7275
|
const data = super.__getData();
|
|
@@ -7369,19 +7459,8 @@ var UI_1;
|
|
|
7369
7459
|
let UI = UI_1 = class UI extends Leaf {
|
|
7370
7460
|
get app() { return this.leafer && this.leafer.app; }
|
|
7371
7461
|
get isFrame() { return false; }
|
|
7372
|
-
set scale(value) {
|
|
7373
|
-
|
|
7374
|
-
this.scaleX = this.scaleY = value;
|
|
7375
|
-
}
|
|
7376
|
-
else {
|
|
7377
|
-
this.scaleX = value.x;
|
|
7378
|
-
this.scaleY = value.y;
|
|
7379
|
-
}
|
|
7380
|
-
}
|
|
7381
|
-
get scale() {
|
|
7382
|
-
const { scaleX, scaleY } = this;
|
|
7383
|
-
return scaleX !== scaleY ? { x: scaleX, y: scaleY } : scaleX;
|
|
7384
|
-
}
|
|
7462
|
+
set scale(value) { MathHelper.assignScale(this, value); }
|
|
7463
|
+
get scale() { return this.__.scale; }
|
|
7385
7464
|
get pen() {
|
|
7386
7465
|
const { path } = this.__;
|
|
7387
7466
|
pen.set(this.path = path || []);
|
|
@@ -7396,8 +7475,15 @@ let UI = UI_1 = class UI extends Leaf {
|
|
|
7396
7475
|
super(data);
|
|
7397
7476
|
}
|
|
7398
7477
|
reset(_data) { }
|
|
7399
|
-
set(data) {
|
|
7400
|
-
|
|
7478
|
+
set(data, isTemp) {
|
|
7479
|
+
if (isTemp) {
|
|
7480
|
+
this.lockNormalStyle = true;
|
|
7481
|
+
Object.assign(this, data);
|
|
7482
|
+
this.lockNormalStyle = false;
|
|
7483
|
+
}
|
|
7484
|
+
else {
|
|
7485
|
+
Object.assign(this, data);
|
|
7486
|
+
}
|
|
7401
7487
|
}
|
|
7402
7488
|
get(name) {
|
|
7403
7489
|
return typeof name === 'string' ? this.__.__getInput(name) : this.__.__getInputData(name);
|
|
@@ -7460,11 +7546,18 @@ let UI = UI_1 = class UI extends Leaf {
|
|
|
7460
7546
|
drawer.rect(x, y, width, height);
|
|
7461
7547
|
}
|
|
7462
7548
|
}
|
|
7549
|
+
animate(_keyframe, _options, _type, _isTemp) {
|
|
7550
|
+
return needPlugin('animate');
|
|
7551
|
+
}
|
|
7552
|
+
killAnimate(_type) { }
|
|
7463
7553
|
export(filename, options) {
|
|
7464
7554
|
return Export.export(this, filename, options);
|
|
7465
7555
|
}
|
|
7466
|
-
clone() {
|
|
7467
|
-
|
|
7556
|
+
clone(data) {
|
|
7557
|
+
const json = this.toJSON();
|
|
7558
|
+
if (data)
|
|
7559
|
+
Object.assign(json, data);
|
|
7560
|
+
return UI_1.one(json);
|
|
7468
7561
|
}
|
|
7469
7562
|
static one(data, x, y, width, height) {
|
|
7470
7563
|
return UICreator.get(data.tag || this.prototype.__tag, data, x, y, width, height);
|
|
@@ -7480,6 +7573,8 @@ let UI = UI_1 = class UI extends Leaf {
|
|
|
7480
7573
|
static setEditInner(_editorName) { }
|
|
7481
7574
|
destroy() {
|
|
7482
7575
|
this.fill = this.stroke = null;
|
|
7576
|
+
if (this.__animate)
|
|
7577
|
+
this.killAnimate();
|
|
7483
7578
|
super.destroy();
|
|
7484
7579
|
}
|
|
7485
7580
|
};
|
|
@@ -7507,12 +7602,6 @@ __decorate([
|
|
|
7507
7602
|
__decorate([
|
|
7508
7603
|
visibleType(true)
|
|
7509
7604
|
], UI.prototype, "visible", void 0);
|
|
7510
|
-
__decorate([
|
|
7511
|
-
stateType(false)
|
|
7512
|
-
], UI.prototype, "selected", void 0);
|
|
7513
|
-
__decorate([
|
|
7514
|
-
stateType(false)
|
|
7515
|
-
], UI.prototype, "disabled", void 0);
|
|
7516
7605
|
__decorate([
|
|
7517
7606
|
surfaceType(false)
|
|
7518
7607
|
], UI.prototype, "locked", void 0);
|
|
@@ -7585,45 +7674,9 @@ __decorate([
|
|
|
7585
7674
|
__decorate([
|
|
7586
7675
|
pathType(true)
|
|
7587
7676
|
], UI.prototype, "closed", void 0);
|
|
7588
|
-
__decorate([
|
|
7589
|
-
autoLayoutType(false)
|
|
7590
|
-
], UI.prototype, "flow", void 0);
|
|
7591
7677
|
__decorate([
|
|
7592
7678
|
boundsType(0)
|
|
7593
7679
|
], UI.prototype, "padding", void 0);
|
|
7594
|
-
__decorate([
|
|
7595
|
-
boundsType(0)
|
|
7596
|
-
], UI.prototype, "gap", void 0);
|
|
7597
|
-
__decorate([
|
|
7598
|
-
boundsType('top-left')
|
|
7599
|
-
], UI.prototype, "flowAlign", void 0);
|
|
7600
|
-
__decorate([
|
|
7601
|
-
boundsType(false)
|
|
7602
|
-
], UI.prototype, "flowWrap", void 0);
|
|
7603
|
-
__decorate([
|
|
7604
|
-
boundsType('box')
|
|
7605
|
-
], UI.prototype, "itemBox", void 0);
|
|
7606
|
-
__decorate([
|
|
7607
|
-
boundsType(true)
|
|
7608
|
-
], UI.prototype, "inFlow", void 0);
|
|
7609
|
-
__decorate([
|
|
7610
|
-
boundsType()
|
|
7611
|
-
], UI.prototype, "autoWidth", void 0);
|
|
7612
|
-
__decorate([
|
|
7613
|
-
boundsType()
|
|
7614
|
-
], UI.prototype, "autoHeight", void 0);
|
|
7615
|
-
__decorate([
|
|
7616
|
-
boundsType()
|
|
7617
|
-
], UI.prototype, "lockRatio", void 0);
|
|
7618
|
-
__decorate([
|
|
7619
|
-
boundsType()
|
|
7620
|
-
], UI.prototype, "autoBox", void 0);
|
|
7621
|
-
__decorate([
|
|
7622
|
-
boundsType()
|
|
7623
|
-
], UI.prototype, "widthRange", void 0);
|
|
7624
|
-
__decorate([
|
|
7625
|
-
boundsType()
|
|
7626
|
-
], UI.prototype, "heightRange", void 0);
|
|
7627
7680
|
__decorate([
|
|
7628
7681
|
dataType(false)
|
|
7629
7682
|
], UI.prototype, "draggable", void 0);
|
|
@@ -7687,12 +7740,6 @@ __decorate([
|
|
|
7687
7740
|
__decorate([
|
|
7688
7741
|
strokeType(10)
|
|
7689
7742
|
], UI.prototype, "miterLimit", void 0);
|
|
7690
|
-
__decorate([
|
|
7691
|
-
arrowType('none')
|
|
7692
|
-
], UI.prototype, "startArrow", void 0);
|
|
7693
|
-
__decorate([
|
|
7694
|
-
arrowType('none')
|
|
7695
|
-
], UI.prototype, "endArrow", void 0);
|
|
7696
7743
|
__decorate([
|
|
7697
7744
|
pathType(0)
|
|
7698
7745
|
], UI.prototype, "cornerRadius", void 0);
|
|
@@ -7714,24 +7761,6 @@ __decorate([
|
|
|
7714
7761
|
__decorate([
|
|
7715
7762
|
effectType()
|
|
7716
7763
|
], UI.prototype, "grayscale", void 0);
|
|
7717
|
-
__decorate([
|
|
7718
|
-
dataType()
|
|
7719
|
-
], UI.prototype, "normalStyle", void 0);
|
|
7720
|
-
__decorate([
|
|
7721
|
-
dataType()
|
|
7722
|
-
], UI.prototype, "hoverStyle", void 0);
|
|
7723
|
-
__decorate([
|
|
7724
|
-
dataType()
|
|
7725
|
-
], UI.prototype, "pressStyle", void 0);
|
|
7726
|
-
__decorate([
|
|
7727
|
-
dataType()
|
|
7728
|
-
], UI.prototype, "focusStyle", void 0);
|
|
7729
|
-
__decorate([
|
|
7730
|
-
dataType()
|
|
7731
|
-
], UI.prototype, "selectedStyle", void 0);
|
|
7732
|
-
__decorate([
|
|
7733
|
-
dataType()
|
|
7734
|
-
], UI.prototype, "disabledStyle", void 0);
|
|
7735
7764
|
__decorate([
|
|
7736
7765
|
dataType({})
|
|
7737
7766
|
], UI.prototype, "data", void 0);
|
|
@@ -7758,7 +7787,7 @@ let Group = class Group extends UI {
|
|
|
7758
7787
|
if (!this.children)
|
|
7759
7788
|
this.children = [];
|
|
7760
7789
|
}
|
|
7761
|
-
set(data) {
|
|
7790
|
+
set(data, isTemp) {
|
|
7762
7791
|
if (data.children) {
|
|
7763
7792
|
const { children } = data;
|
|
7764
7793
|
delete data.children;
|
|
@@ -7768,7 +7797,7 @@ let Group = class Group extends UI {
|
|
|
7768
7797
|
else {
|
|
7769
7798
|
this.clear();
|
|
7770
7799
|
}
|
|
7771
|
-
super.set(data);
|
|
7800
|
+
super.set(data, isTemp);
|
|
7772
7801
|
let child;
|
|
7773
7802
|
children.forEach(childData => {
|
|
7774
7803
|
child = childData.__ ? childData : UICreator.get(childData.tag, childData);
|
|
@@ -7777,7 +7806,7 @@ let Group = class Group extends UI {
|
|
|
7777
7806
|
data.children = children;
|
|
7778
7807
|
}
|
|
7779
7808
|
else {
|
|
7780
|
-
super.set(data);
|
|
7809
|
+
super.set(data, isTemp);
|
|
7781
7810
|
}
|
|
7782
7811
|
}
|
|
7783
7812
|
toJSON(options) {
|
|
@@ -8104,7 +8133,7 @@ let Leafer = Leafer_1 = class Leafer extends Group {
|
|
|
8104
8133
|
}
|
|
8105
8134
|
}
|
|
8106
8135
|
zoom(_zoomType, _padding, _fixedScale) {
|
|
8107
|
-
return
|
|
8136
|
+
return needPlugin('view');
|
|
8108
8137
|
}
|
|
8109
8138
|
getValidMove(moveX, moveY) { return { x: moveX, y: moveY }; }
|
|
8110
8139
|
getValidScale(changeScale) { return changeScale; }
|
|
@@ -8627,19 +8656,18 @@ let Canvas = class Canvas extends Rect {
|
|
|
8627
8656
|
this.paint();
|
|
8628
8657
|
}
|
|
8629
8658
|
paint() {
|
|
8630
|
-
this.
|
|
8659
|
+
this.forceRender();
|
|
8631
8660
|
}
|
|
8632
8661
|
__drawAfterFill(canvas, _options) {
|
|
8633
|
-
const
|
|
8634
|
-
|
|
8635
|
-
if (this.__.cornerRadius || this.pathInputed) {
|
|
8662
|
+
const { width, height, cornerRadius } = this.__, { view } = this.canvas;
|
|
8663
|
+
if (cornerRadius || this.pathInputed) {
|
|
8636
8664
|
canvas.save();
|
|
8637
8665
|
canvas.clip();
|
|
8638
|
-
canvas.drawImage(
|
|
8666
|
+
canvas.drawImage(view, 0, 0, view.width, view.height, 0, 0, width, height);
|
|
8639
8667
|
canvas.restore();
|
|
8640
8668
|
}
|
|
8641
8669
|
else {
|
|
8642
|
-
canvas.drawImage(
|
|
8670
|
+
canvas.drawImage(view, 0, 0, view.width, view.height, 0, 0, width, height);
|
|
8643
8671
|
}
|
|
8644
8672
|
}
|
|
8645
8673
|
__updateSize() {
|
|
@@ -9082,21 +9110,29 @@ class UIEvent extends Event {
|
|
|
9082
9110
|
constructor(params) {
|
|
9083
9111
|
super(params.type);
|
|
9084
9112
|
this.bubbles = true;
|
|
9113
|
+
this.getInner = this.getInnerPoint;
|
|
9114
|
+
this.getLocal = this.getLocalPoint;
|
|
9115
|
+
this.getPage = this.getPagePoint;
|
|
9085
9116
|
Object.assign(this, params);
|
|
9086
9117
|
}
|
|
9087
|
-
|
|
9088
|
-
|
|
9118
|
+
getBoxPoint(relative) {
|
|
9119
|
+
if (!relative)
|
|
9120
|
+
relative = this.current;
|
|
9121
|
+
return relative.getBoxPoint(this);
|
|
9089
9122
|
}
|
|
9090
|
-
|
|
9123
|
+
getInnerPoint(relative) {
|
|
9091
9124
|
if (!relative)
|
|
9092
9125
|
relative = this.current;
|
|
9093
9126
|
return relative.getInnerPoint(this);
|
|
9094
9127
|
}
|
|
9095
|
-
|
|
9128
|
+
getLocalPoint(relative) {
|
|
9096
9129
|
if (!relative)
|
|
9097
9130
|
relative = this.current;
|
|
9098
9131
|
return relative.getLocalPoint(this);
|
|
9099
9132
|
}
|
|
9133
|
+
getPagePoint() {
|
|
9134
|
+
return this.current.getPagePoint(this);
|
|
9135
|
+
}
|
|
9100
9136
|
static changeName(oldName, newName) {
|
|
9101
9137
|
EventCreator.changeName(oldName, newName);
|
|
9102
9138
|
}
|
|
@@ -9204,7 +9240,7 @@ let DragEvent = class DragEvent extends PointerEvent {
|
|
|
9204
9240
|
}
|
|
9205
9241
|
getPageBounds() {
|
|
9206
9242
|
const total = this.getPageTotal();
|
|
9207
|
-
const start = this.
|
|
9243
|
+
const start = this.getPagePoint();
|
|
9208
9244
|
const bounds = {};
|
|
9209
9245
|
BoundsHelper.set(bounds, start.x - total.x, start.y - total.y, total.x, total.y);
|
|
9210
9246
|
BoundsHelper.unsign(bounds);
|
|
@@ -9788,7 +9824,7 @@ function emitEvent(leaf, type, data, capture, excludePath) {
|
|
|
9788
9824
|
if (leaf.destroyed)
|
|
9789
9825
|
return false;
|
|
9790
9826
|
if (leaf.__.hitSelf && !exclude(leaf, excludePath)) {
|
|
9791
|
-
if (State.updateEventStyle)
|
|
9827
|
+
if (State.updateEventStyle && !capture)
|
|
9792
9828
|
State.updateEventStyle(leaf, type);
|
|
9793
9829
|
if (leaf.hasEvent(type, capture)) {
|
|
9794
9830
|
data.phase = capture ? 1 : ((leaf === data.target) ? 2 : 3);
|
|
@@ -9893,7 +9929,7 @@ class InteractionBase {
|
|
|
9893
9929
|
this.tapWait();
|
|
9894
9930
|
this.longPressWait(data);
|
|
9895
9931
|
}
|
|
9896
|
-
this.
|
|
9932
|
+
this.waitRightTap = PointerButton.right(data);
|
|
9897
9933
|
this.dragger.setDragData(data);
|
|
9898
9934
|
if (!this.isHoldRightKey)
|
|
9899
9935
|
this.updateCursor(data);
|
|
@@ -9921,7 +9957,7 @@ class InteractionBase {
|
|
|
9921
9957
|
if (canDrag) {
|
|
9922
9958
|
if (this.waitTap)
|
|
9923
9959
|
this.pointerWaitCancel();
|
|
9924
|
-
this.
|
|
9960
|
+
this.waitRightTap = false;
|
|
9925
9961
|
}
|
|
9926
9962
|
this.dragger.checkDrag(data, canDrag);
|
|
9927
9963
|
}
|
|
@@ -9975,10 +10011,15 @@ class InteractionBase {
|
|
|
9975
10011
|
menu(data) {
|
|
9976
10012
|
this.findPath(data);
|
|
9977
10013
|
this.emit(PointerEvent.MENU, data);
|
|
10014
|
+
this.waitMenuTap = true;
|
|
10015
|
+
if (!this.downData && this.waitRightTap)
|
|
10016
|
+
this.menuTap(data);
|
|
9978
10017
|
}
|
|
9979
10018
|
menuTap(data) {
|
|
9980
|
-
if (this.waitMenuTap)
|
|
10019
|
+
if (this.waitRightTap && this.waitMenuTap) {
|
|
9981
10020
|
this.emit(PointerEvent.MENU_TAP, data);
|
|
10021
|
+
this.waitRightTap = this.waitMenuTap = false;
|
|
10022
|
+
}
|
|
9982
10023
|
}
|
|
9983
10024
|
move(data) {
|
|
9984
10025
|
this.transformer.move(data);
|
|
@@ -10927,6 +10968,8 @@ function getPatternData(paint, box, image) {
|
|
|
10927
10968
|
let { width, height } = image;
|
|
10928
10969
|
if (paint.padding)
|
|
10929
10970
|
box = tempBox.set(box).shrink(paint.padding);
|
|
10971
|
+
if (paint.mode === 'strench')
|
|
10972
|
+
paint.mode = 'stretch';
|
|
10930
10973
|
const { opacity, mode, align, offset, scale, size, rotation, repeat } = paint;
|
|
10931
10974
|
const sameBox = box.width === width && box.height === height;
|
|
10932
10975
|
const data = { mode };
|
|
@@ -10955,7 +10998,7 @@ function getPatternData(paint, box, image) {
|
|
|
10955
10998
|
if (offset)
|
|
10956
10999
|
x += offset.x, y += offset.y;
|
|
10957
11000
|
switch (mode) {
|
|
10958
|
-
case '
|
|
11001
|
+
case 'stretch':
|
|
10959
11002
|
if (!sameBox)
|
|
10960
11003
|
width = box.width, height = box.height;
|
|
10961
11004
|
break;
|
|
@@ -10982,7 +11025,7 @@ function getPatternData(paint, box, image) {
|
|
|
10982
11025
|
translate(data.transform, box.x, box.y);
|
|
10983
11026
|
}
|
|
10984
11027
|
}
|
|
10985
|
-
if (scaleX && mode !== '
|
|
11028
|
+
if (scaleX && mode !== 'stretch') {
|
|
10986
11029
|
data.scaleX = scaleX;
|
|
10987
11030
|
data.scaleY = scaleY;
|
|
10988
11031
|
}
|
|
@@ -11086,7 +11129,7 @@ const { get: get$1, scale, copy: copy$1 } = MatrixHelper;
|
|
|
11086
11129
|
const { ceil, abs: abs$1 } = Math;
|
|
11087
11130
|
function createPattern(ui, paint, pixelRatio) {
|
|
11088
11131
|
let { scaleX, scaleY } = ImageManager.patternLocked ? ui.__world : ui.__nowWorld;
|
|
11089
|
-
const id = scaleX + '-' + scaleY;
|
|
11132
|
+
const id = scaleX + '-' + scaleY + '-' + pixelRatio;
|
|
11090
11133
|
if (paint.patternId !== id && !ui.destroyed) {
|
|
11091
11134
|
scaleX = abs$1(scaleX);
|
|
11092
11135
|
scaleY = abs$1(scaleY);
|
|
@@ -11148,7 +11191,8 @@ function createPattern(ui, paint, pixelRatio) {
|
|
|
11148
11191
|
const { abs } = Math;
|
|
11149
11192
|
function checkImage(ui, canvas, paint, allowPaint) {
|
|
11150
11193
|
const { scaleX, scaleY } = ImageManager.patternLocked ? ui.__world : ui.__nowWorld;
|
|
11151
|
-
|
|
11194
|
+
const { pixelRatio } = canvas;
|
|
11195
|
+
if (!paint.data || (paint.patternId === scaleX + '-' + scaleY + '-' + pixelRatio && !Export.running)) {
|
|
11152
11196
|
return false;
|
|
11153
11197
|
}
|
|
11154
11198
|
else {
|
|
@@ -11156,8 +11200,8 @@ function checkImage(ui, canvas, paint, allowPaint) {
|
|
|
11156
11200
|
if (allowPaint) {
|
|
11157
11201
|
if (!data.repeat) {
|
|
11158
11202
|
let { width, height } = data;
|
|
11159
|
-
width *= abs(scaleX) *
|
|
11160
|
-
height *= abs(scaleY) *
|
|
11203
|
+
width *= abs(scaleX) * pixelRatio;
|
|
11204
|
+
height *= abs(scaleY) * pixelRatio;
|
|
11161
11205
|
if (data.scaleX) {
|
|
11162
11206
|
width *= data.scaleX;
|
|
11163
11207
|
height *= data.scaleY;
|
|
@@ -11183,14 +11227,14 @@ function checkImage(ui, canvas, paint, allowPaint) {
|
|
|
11183
11227
|
}
|
|
11184
11228
|
else {
|
|
11185
11229
|
if (!paint.style || paint.sync || Export.running) {
|
|
11186
|
-
createPattern(ui, paint,
|
|
11230
|
+
createPattern(ui, paint, pixelRatio);
|
|
11187
11231
|
}
|
|
11188
11232
|
else {
|
|
11189
11233
|
if (!paint.patternTask) {
|
|
11190
11234
|
paint.patternTask = ImageManager.patternTasker.add(() => __awaiter(this, void 0, void 0, function* () {
|
|
11191
11235
|
paint.patternTask = null;
|
|
11192
11236
|
if (canvas.bounds.hit(ui.__nowWorld))
|
|
11193
|
-
createPattern(ui, paint,
|
|
11237
|
+
createPattern(ui, paint, pixelRatio);
|
|
11194
11238
|
ui.forceUpdate('surface');
|
|
11195
11239
|
}), 300);
|
|
11196
11240
|
}
|
|
@@ -11254,14 +11298,16 @@ function linearGradient(paint, box) {
|
|
|
11254
11298
|
return data;
|
|
11255
11299
|
}
|
|
11256
11300
|
function applyStops(gradient, stops, opacity) {
|
|
11257
|
-
|
|
11258
|
-
|
|
11259
|
-
|
|
11260
|
-
|
|
11261
|
-
|
|
11262
|
-
|
|
11263
|
-
|
|
11264
|
-
|
|
11301
|
+
if (stops) {
|
|
11302
|
+
let stop;
|
|
11303
|
+
for (let i = 0, len = stops.length; i < len; i++) {
|
|
11304
|
+
stop = stops[i];
|
|
11305
|
+
if (typeof stop === 'string') {
|
|
11306
|
+
gradient.addColorStop(i / (len - 1), ColorConvert.string(stop, opacity));
|
|
11307
|
+
}
|
|
11308
|
+
else {
|
|
11309
|
+
gradient.addColorStop(stop.offset, ColorConvert.string(stop.color, opacity));
|
|
11310
|
+
}
|
|
11265
11311
|
}
|
|
11266
11312
|
}
|
|
11267
11313
|
}
|
|
@@ -12017,10 +12063,15 @@ const TextConvertModule = {
|
|
|
12017
12063
|
};
|
|
12018
12064
|
|
|
12019
12065
|
function string(color, opacity) {
|
|
12020
|
-
|
|
12021
|
-
|
|
12066
|
+
const doOpacity = typeof opacity === 'number' && opacity !== 1;
|
|
12067
|
+
if (typeof color === 'string') {
|
|
12068
|
+
if (doOpacity && ColorConvert.object)
|
|
12069
|
+
color = ColorConvert.object(color);
|
|
12070
|
+
else
|
|
12071
|
+
return color;
|
|
12072
|
+
}
|
|
12022
12073
|
let a = color.a === undefined ? 1 : color.a;
|
|
12023
|
-
if (
|
|
12074
|
+
if (doOpacity)
|
|
12024
12075
|
a *= opacity;
|
|
12025
12076
|
const rgb = color.r + ',' + color.g + ',' + color.b;
|
|
12026
12077
|
return a === 1 ? 'rgb(' + rgb + ')' : 'rgba(' + rgb + ',' + a + ')';
|
|
@@ -12263,4 +12314,4 @@ if (platform === 'ios') {
|
|
|
12263
12314
|
};
|
|
12264
12315
|
}
|
|
12265
12316
|
|
|
12266
|
-
export { AlignHelper,
|
|
12317
|
+
export { AlignHelper, Answer, App, AroundHelper, AutoBounds, BezierHelper, Bounds, BoundsHelper, Box, BoxData, Branch, BranchHelper, BranchRender, Canvas, CanvasData, CanvasManager, ChildEvent, ColorConvert, Creator, Cursor, DataHelper, Debug, Direction4, Direction9, DragEvent, DropEvent, Effect, Ellipse, EllipseData, EllipseHelper, Event, EventCreator, Eventer, Export, FileHelper, Frame, FrameData, Group, GroupData, HitCanvasManager, Image, ImageData, ImageEvent, ImageManager, IncrementId, Interaction, InteractionBase, InteractionHelper, KeyEvent, Keyboard, LayoutEvent, Layouter, Leaf, LeafBounds, LeafBoundsHelper, LeafData, LeafDataProxy, LeafEventer, LeafHelper, LeafLayout, LeafLevelList, LeafList, LeafMatrix, LeafRender, Leafer, LeaferCanvas, LeaferCanvasBase, LeaferData, LeaferEvent, LeaferImage, LeaferTypeCreator, Line, LineData, MathHelper, Matrix, MatrixHelper, MoveEvent, MultiTouchHelper, MyDragEvent, MyImage, MyPointerEvent, 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, PointerButton, PointerEvent, Polygon, PolygonData, PropertyEvent, Rect, RectData, RectHelper, RectRender, RenderEvent, Renderer, ResizeEvent, RotateEvent, Run, Selector, Star, StarData, State, StringNumberMap, SwipeEvent, TaskItem, TaskProcessor, Text, TextConvert, TextData, Transition, TwoPointBoundsHelper, UI, UIBounds, UICreator, UIData, UIEvent, UIRender, UnitConvert, WaitHelper, WatchEvent, Watcher, ZoomEvent, addInteractionWindow, affectRenderBoundsType, affectStrokeBoundsType, attr, autoLayoutType, boundsType, canvasPatch, canvasSizeAttrs, cursorType, dataProcessor, dataType, decorateLeafAttr, defineDataProcessor, defineKey, defineLeafAttr, doBoundsType, doStrokeType, effectType, emptyData, eraserType, getBoundsData, getDescriptor, getMatrixData, getPointData, hitType, isNull, layoutProcessor, maskType, naturalBoundsType, needPlugin, opacityType, pathInputType, pathType, pen, positionType, registerUI, registerUIEvent, resizeType, rewrite, rewriteAble, rotationType, scaleType, sortType, strokeType, surfaceType, tempBounds$1 as tempBounds, tempMatrix, tempPoint$3 as tempPoint, useCanvas, useModule, version, visibleType, zoomLayerType };
|