leafer-ui 1.2.2 → 1.3.0
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/web.cjs +25 -326
- package/dist/web.esm.js +26 -328
- package/dist/web.esm.min.js +1 -1
- package/dist/web.js +136 -439
- package/dist/web.min.cjs +1 -1
- package/dist/web.min.js +1 -1
- package/dist/web.module.js +136 -440
- package/dist/web.module.min.js +1 -1
- package/package.json +12 -12
package/dist/web.js
CHANGED
|
@@ -768,8 +768,8 @@ var LeaferUI = (function (exports) {
|
|
|
768
768
|
t.maxY = y > t.maxY ? y : t.maxY;
|
|
769
769
|
},
|
|
770
770
|
addBounds(t, x, y, width, height) {
|
|
771
|
-
addPoint$
|
|
772
|
-
addPoint$
|
|
771
|
+
addPoint$3(t, x, y);
|
|
772
|
+
addPoint$3(t, x + width, y + height);
|
|
773
773
|
},
|
|
774
774
|
copy(t, pb) {
|
|
775
775
|
t.minX = pb.minX;
|
|
@@ -790,9 +790,9 @@ var LeaferUI = (function (exports) {
|
|
|
790
790
|
setBounds.height = t.maxY - t.minY;
|
|
791
791
|
}
|
|
792
792
|
};
|
|
793
|
-
const { addPoint: addPoint$
|
|
793
|
+
const { addPoint: addPoint$3 } = TwoPointBoundsHelper;
|
|
794
794
|
|
|
795
|
-
const { tempPointBounds: tempPointBounds$1, setPoint: setPoint$
|
|
795
|
+
const { tempPointBounds: tempPointBounds$1, setPoint: setPoint$2, addPoint: addPoint$2, toBounds: toBounds$3 } = TwoPointBoundsHelper;
|
|
796
796
|
const { toOuterPoint: toOuterPoint$2 } = MatrixHelper;
|
|
797
797
|
const { float, fourNumber } = MathHelper;
|
|
798
798
|
const { floor, ceil: ceil$2 } = Math;
|
|
@@ -908,17 +908,17 @@ var LeaferUI = (function (exports) {
|
|
|
908
908
|
point.x = t.x;
|
|
909
909
|
point.y = t.y;
|
|
910
910
|
toOuterPoint$2(matrix, point, toPoint$5);
|
|
911
|
-
setPoint$
|
|
911
|
+
setPoint$2(tempPointBounds$1, toPoint$5.x, toPoint$5.y);
|
|
912
912
|
point.x = t.x + t.width;
|
|
913
913
|
toOuterPoint$2(matrix, point, toPoint$5);
|
|
914
|
-
addPoint$
|
|
914
|
+
addPoint$2(tempPointBounds$1, toPoint$5.x, toPoint$5.y);
|
|
915
915
|
point.y = t.y + t.height;
|
|
916
916
|
toOuterPoint$2(matrix, point, toPoint$5);
|
|
917
|
-
addPoint$
|
|
917
|
+
addPoint$2(tempPointBounds$1, toPoint$5.x, toPoint$5.y);
|
|
918
918
|
point.x = t.x;
|
|
919
919
|
toOuterPoint$2(matrix, point, toPoint$5);
|
|
920
|
-
addPoint$
|
|
921
|
-
toBounds$
|
|
920
|
+
addPoint$2(tempPointBounds$1, toPoint$5.x, toPoint$5.y);
|
|
921
|
+
toBounds$3(tempPointBounds$1, to);
|
|
922
922
|
}
|
|
923
923
|
},
|
|
924
924
|
toInnerOf(t, matrix, to) {
|
|
@@ -1008,8 +1008,8 @@ var LeaferUI = (function (exports) {
|
|
|
1008
1008
|
B.reset(t);
|
|
1009
1009
|
},
|
|
1010
1010
|
setPoints(t, points) {
|
|
1011
|
-
points.forEach((point, index) => index === 0 ? setPoint$
|
|
1012
|
-
toBounds$
|
|
1011
|
+
points.forEach((point, index) => index === 0 ? setPoint$2(tempPointBounds$1, point.x, point.y) : addPoint$2(tempPointBounds$1, point.x, point.y));
|
|
1012
|
+
toBounds$3(tempPointBounds$1, t);
|
|
1013
1013
|
},
|
|
1014
1014
|
setPoint(t, point) {
|
|
1015
1015
|
B.set(t, point.x, point.y);
|
|
@@ -1377,7 +1377,7 @@ var LeaferUI = (function (exports) {
|
|
|
1377
1377
|
}
|
|
1378
1378
|
const D$4 = Debug;
|
|
1379
1379
|
|
|
1380
|
-
const debug$
|
|
1380
|
+
const debug$f = Debug.get('RunTime');
|
|
1381
1381
|
const Run = {
|
|
1382
1382
|
currentId: 0,
|
|
1383
1383
|
currentName: '',
|
|
@@ -1395,7 +1395,7 @@ var LeaferUI = (function (exports) {
|
|
|
1395
1395
|
const time = R.idMap[id], name = R.nameMap[id];
|
|
1396
1396
|
const duration = microsecond ? (performance.now() - time) / 1000 : Date.now() - time;
|
|
1397
1397
|
R.idMap[id] = R.nameMap[id] = R.nameToIdMap[name] = undefined;
|
|
1398
|
-
debug$
|
|
1398
|
+
debug$f.log(name, duration, 'ms');
|
|
1399
1399
|
},
|
|
1400
1400
|
endOfName(name, microsecond) {
|
|
1401
1401
|
const id = R.nameToIdMap[name];
|
|
@@ -1405,34 +1405,37 @@ var LeaferUI = (function (exports) {
|
|
|
1405
1405
|
};
|
|
1406
1406
|
const R = Run;
|
|
1407
1407
|
|
|
1408
|
+
const check = [];
|
|
1408
1409
|
const Plugin = {
|
|
1409
1410
|
list: {},
|
|
1410
|
-
add(name) {
|
|
1411
|
+
add(name, ...needPlugins) {
|
|
1411
1412
|
this.list[name] = true;
|
|
1413
|
+
check.push(...needPlugins);
|
|
1412
1414
|
},
|
|
1413
|
-
|
|
1415
|
+
has(name, tip) {
|
|
1414
1416
|
const rs = this.list[name];
|
|
1415
1417
|
if (!rs && tip)
|
|
1416
1418
|
this.need(name);
|
|
1417
1419
|
return rs;
|
|
1418
1420
|
},
|
|
1419
1421
|
need(name) {
|
|
1420
|
-
console.error('need plugin: @leafer-in/' + name);
|
|
1422
|
+
console.error('need plugin: ' + (name.includes('-x') ? '' : '@leafer-in/') + name);
|
|
1421
1423
|
}
|
|
1422
1424
|
};
|
|
1425
|
+
setTimeout(() => check.forEach(name => Plugin.has(name, true)));
|
|
1423
1426
|
|
|
1424
|
-
const debug$
|
|
1427
|
+
const debug$e = Debug.get('UICreator');
|
|
1425
1428
|
const UICreator = {
|
|
1426
1429
|
list: {},
|
|
1427
1430
|
register(UI) {
|
|
1428
1431
|
const { __tag: tag } = UI.prototype;
|
|
1429
1432
|
if (list$1[tag])
|
|
1430
|
-
debug$
|
|
1433
|
+
debug$e.repeat(tag);
|
|
1431
1434
|
list$1[tag] = UI;
|
|
1432
1435
|
},
|
|
1433
1436
|
get(tag, data, x, y, width, height) {
|
|
1434
1437
|
if (!list$1[tag])
|
|
1435
|
-
debug$
|
|
1438
|
+
debug$e.error('not register ' + tag);
|
|
1436
1439
|
const ui = new list$1[tag](data);
|
|
1437
1440
|
if (x !== undefined) {
|
|
1438
1441
|
ui.x = x;
|
|
@@ -1448,7 +1451,7 @@ var LeaferUI = (function (exports) {
|
|
|
1448
1451
|
};
|
|
1449
1452
|
const { list: list$1 } = UICreator;
|
|
1450
1453
|
|
|
1451
|
-
const debug$
|
|
1454
|
+
const debug$d = Debug.get('EventCreator');
|
|
1452
1455
|
const EventCreator = {
|
|
1453
1456
|
nameList: {},
|
|
1454
1457
|
register(Event) {
|
|
@@ -1456,7 +1459,7 @@ var LeaferUI = (function (exports) {
|
|
|
1456
1459
|
Object.keys(Event).forEach(key => {
|
|
1457
1460
|
name = Event[key];
|
|
1458
1461
|
if (typeof name === 'string')
|
|
1459
|
-
nameList[name] && debug$
|
|
1462
|
+
nameList[name] && debug$d.repeat(name), nameList[name] = Event;
|
|
1460
1463
|
});
|
|
1461
1464
|
},
|
|
1462
1465
|
changeName(oldName, newName) {
|
|
@@ -2345,7 +2348,7 @@ var LeaferUI = (function (exports) {
|
|
|
2345
2348
|
};
|
|
2346
2349
|
|
|
2347
2350
|
const { sin: sin$3, cos: cos$3, atan2: atan2$1, ceil: ceil$1, abs: abs$3, PI: PI$2, sqrt: sqrt$1, pow } = Math;
|
|
2348
|
-
const { setPoint: setPoint$
|
|
2351
|
+
const { setPoint: setPoint$1, addPoint: addPoint$1 } = TwoPointBoundsHelper;
|
|
2349
2352
|
const { set, toNumberPoints } = PointHelper;
|
|
2350
2353
|
const { M: M$5, L: L$6, C: C$5, Q: Q$4, Z: Z$5 } = PathCommandMap;
|
|
2351
2354
|
const tempPoint$2 = {};
|
|
@@ -2421,8 +2424,8 @@ var LeaferUI = (function (exports) {
|
|
|
2421
2424
|
if (data)
|
|
2422
2425
|
data.push(L$6, x1, y1);
|
|
2423
2426
|
if (setPointBounds) {
|
|
2424
|
-
setPoint$
|
|
2425
|
-
addPoint$
|
|
2427
|
+
setPoint$1(setPointBounds, fromX, fromY);
|
|
2428
|
+
addPoint$1(setPointBounds, x1, y1);
|
|
2426
2429
|
}
|
|
2427
2430
|
if (setStartPoint)
|
|
2428
2431
|
set(setStartPoint, fromX, fromY);
|
|
@@ -2474,7 +2477,7 @@ var LeaferUI = (function (exports) {
|
|
|
2474
2477
|
if (data)
|
|
2475
2478
|
data.push(data.length ? L$6 : M$5, fromX, fromY);
|
|
2476
2479
|
if (setPointBounds)
|
|
2477
|
-
setPoint$
|
|
2480
|
+
setPoint$1(setPointBounds, fromX, fromY);
|
|
2478
2481
|
if (setStartPoint)
|
|
2479
2482
|
set(setStartPoint, fromX, fromY);
|
|
2480
2483
|
for (let i = 0; i < parts; i++) {
|
|
@@ -2536,11 +2539,11 @@ var LeaferUI = (function (exports) {
|
|
|
2536
2539
|
if (0 < t2 && t2 < 1)
|
|
2537
2540
|
tList.push(t2);
|
|
2538
2541
|
}
|
|
2539
|
-
addMode ? addPoint$
|
|
2540
|
-
addPoint$
|
|
2542
|
+
addMode ? addPoint$1(pointBounds, fromX, fromY) : setPoint$1(pointBounds, fromX, fromY);
|
|
2543
|
+
addPoint$1(pointBounds, toX, toY);
|
|
2541
2544
|
for (let i = 0, len = tList.length; i < len; i++) {
|
|
2542
2545
|
getPointAndSet(tList[i], fromX, fromY, x1, y1, x2, y2, toX, toY, tempPoint$2);
|
|
2543
|
-
addPoint$
|
|
2546
|
+
addPoint$1(pointBounds, tempPoint$2.x, tempPoint$2.y);
|
|
2544
2547
|
}
|
|
2545
2548
|
},
|
|
2546
2549
|
getPointAndSet(t, fromX, fromY, x1, y1, x2, y2, toX, toY, setPoint) {
|
|
@@ -2612,7 +2615,7 @@ var LeaferUI = (function (exports) {
|
|
|
2612
2615
|
const { M: M$4, m, L: L$5, l, H, h, V, v, C: C$4, c, S, s, Q: Q$3, q, T, t, A, a, Z: Z$4, z, N: N$3, D: D$3, X: X$3, G: G$3, F: F$4, O: O$3, P: P$3, U: U$3 } = PathCommandMap;
|
|
2613
2616
|
const { rect: rect$3, roundRect: roundRect$2, arcTo: arcTo$3, arc: arc$3, ellipse: ellipse$4, quadraticCurveTo: quadraticCurveTo$1 } = BezierHelper;
|
|
2614
2617
|
const { ellipticalArc } = EllipseHelper;
|
|
2615
|
-
const debug$
|
|
2618
|
+
const debug$c = Debug.get('PathConvert');
|
|
2616
2619
|
const setEndPoint$1 = {};
|
|
2617
2620
|
const PathConvert = {
|
|
2618
2621
|
current: { dot: 0 },
|
|
@@ -2853,7 +2856,7 @@ var LeaferUI = (function (exports) {
|
|
|
2853
2856
|
i += 6;
|
|
2854
2857
|
break;
|
|
2855
2858
|
default:
|
|
2856
|
-
debug$
|
|
2859
|
+
debug$c.error(`command: ${command} [index:${i}]`, old);
|
|
2857
2860
|
return data;
|
|
2858
2861
|
}
|
|
2859
2862
|
lastCommand = command;
|
|
@@ -3078,7 +3081,7 @@ var LeaferUI = (function (exports) {
|
|
|
3078
3081
|
}
|
|
3079
3082
|
|
|
3080
3083
|
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;
|
|
3081
|
-
const debug$
|
|
3084
|
+
const debug$b = Debug.get('PathDrawer');
|
|
3082
3085
|
const PathDrawer = {
|
|
3083
3086
|
drawPathByData(drawer, data) {
|
|
3084
3087
|
if (!data)
|
|
@@ -3141,7 +3144,7 @@ var LeaferUI = (function (exports) {
|
|
|
3141
3144
|
i += 6;
|
|
3142
3145
|
break;
|
|
3143
3146
|
default:
|
|
3144
|
-
debug$
|
|
3147
|
+
debug$b.error(`command: ${command} [index:${i}]`, data);
|
|
3145
3148
|
return;
|
|
3146
3149
|
}
|
|
3147
3150
|
}
|
|
@@ -3150,8 +3153,8 @@ var LeaferUI = (function (exports) {
|
|
|
3150
3153
|
|
|
3151
3154
|
const { M: M$1, L: L$2, C: C$1, Q, Z: Z$1, N, D, X, G, F: F$1, O, P, U } = PathCommandMap;
|
|
3152
3155
|
const { toTwoPointBounds, toTwoPointBoundsByQuadraticCurve, arcTo: arcTo$1, arc, ellipse: ellipse$1 } = BezierHelper;
|
|
3153
|
-
const { addPointBounds, copy: copy$8, addPoint
|
|
3154
|
-
const debug$
|
|
3156
|
+
const { addPointBounds, copy: copy$8, addPoint, setPoint, addBounds, toBounds: toBounds$2 } = TwoPointBoundsHelper;
|
|
3157
|
+
const debug$a = Debug.get('PathBounds');
|
|
3155
3158
|
let radius, radiusX, radiusY;
|
|
3156
3159
|
const tempPointBounds = {};
|
|
3157
3160
|
const setPointBounds = {};
|
|
@@ -3159,21 +3162,21 @@ var LeaferUI = (function (exports) {
|
|
|
3159
3162
|
const PathBounds = {
|
|
3160
3163
|
toBounds(data, setBounds) {
|
|
3161
3164
|
PathBounds.toTwoPointBounds(data, setPointBounds);
|
|
3162
|
-
toBounds$
|
|
3165
|
+
toBounds$2(setPointBounds, setBounds);
|
|
3163
3166
|
},
|
|
3164
3167
|
toTwoPointBounds(data, setPointBounds) {
|
|
3165
3168
|
if (!data || !data.length)
|
|
3166
|
-
return setPoint
|
|
3169
|
+
return setPoint(setPointBounds, 0, 0);
|
|
3167
3170
|
let i = 0, x = 0, y = 0, x1, y1, toX, toY, command;
|
|
3168
3171
|
const len = data.length;
|
|
3169
3172
|
while (i < len) {
|
|
3170
3173
|
command = data[i];
|
|
3171
3174
|
if (i === 0) {
|
|
3172
3175
|
if (command === Z$1 || command === C$1 || command === Q) {
|
|
3173
|
-
setPoint
|
|
3176
|
+
setPoint(setPointBounds, x, y);
|
|
3174
3177
|
}
|
|
3175
3178
|
else {
|
|
3176
|
-
setPoint
|
|
3179
|
+
setPoint(setPointBounds, data[i + 1], data[i + 2]);
|
|
3177
3180
|
}
|
|
3178
3181
|
}
|
|
3179
3182
|
switch (command) {
|
|
@@ -3181,7 +3184,7 @@ var LeaferUI = (function (exports) {
|
|
|
3181
3184
|
case L$2:
|
|
3182
3185
|
x = data[i + 1];
|
|
3183
3186
|
y = data[i + 2];
|
|
3184
|
-
addPoint
|
|
3187
|
+
addPoint(setPointBounds, x, y);
|
|
3185
3188
|
i += 3;
|
|
3186
3189
|
break;
|
|
3187
3190
|
case C$1:
|
|
@@ -3259,7 +3262,7 @@ var LeaferUI = (function (exports) {
|
|
|
3259
3262
|
i += 6;
|
|
3260
3263
|
break;
|
|
3261
3264
|
default:
|
|
3262
|
-
debug$
|
|
3265
|
+
debug$a.error(`command: ${command} [index:${i}]`, data);
|
|
3263
3266
|
return;
|
|
3264
3267
|
}
|
|
3265
3268
|
}
|
|
@@ -3375,7 +3378,7 @@ var LeaferUI = (function (exports) {
|
|
|
3375
3378
|
const F = FileHelper;
|
|
3376
3379
|
F.opacityTypes.forEach(type => F.upperCaseTypeMap[type] = type.toUpperCase());
|
|
3377
3380
|
|
|
3378
|
-
const debug$
|
|
3381
|
+
const debug$9 = Debug.get('TaskProcessor');
|
|
3379
3382
|
class TaskItem {
|
|
3380
3383
|
constructor(task) {
|
|
3381
3384
|
this.parallel = true;
|
|
@@ -3390,7 +3393,7 @@ var LeaferUI = (function (exports) {
|
|
|
3390
3393
|
yield this.task();
|
|
3391
3394
|
}
|
|
3392
3395
|
catch (error) {
|
|
3393
|
-
debug$
|
|
3396
|
+
debug$9.error(error);
|
|
3394
3397
|
}
|
|
3395
3398
|
});
|
|
3396
3399
|
}
|
|
@@ -4077,7 +4080,7 @@ var LeaferUI = (function (exports) {
|
|
|
4077
4080
|
defineKey(data, key, property);
|
|
4078
4081
|
}
|
|
4079
4082
|
|
|
4080
|
-
const debug$
|
|
4083
|
+
const debug$8 = new Debug('rewrite');
|
|
4081
4084
|
const list = [];
|
|
4082
4085
|
const excludeNames = ['destroy', 'constructor'];
|
|
4083
4086
|
function rewrite(method) {
|
|
@@ -4094,7 +4097,7 @@ var LeaferUI = (function (exports) {
|
|
|
4094
4097
|
if (list.length) {
|
|
4095
4098
|
list.forEach(item => {
|
|
4096
4099
|
if (error)
|
|
4097
|
-
debug$
|
|
4100
|
+
debug$8.error(item.name, '需在Class上装饰@rewriteAble()');
|
|
4098
4101
|
item.run();
|
|
4099
4102
|
});
|
|
4100
4103
|
list.length = 0;
|
|
@@ -4811,7 +4814,6 @@ var LeaferUI = (function (exports) {
|
|
|
4811
4814
|
}
|
|
4812
4815
|
}
|
|
4813
4816
|
}
|
|
4814
|
-
LayoutEvent.CHECK_UPDATE = 'layout.check_update';
|
|
4815
4817
|
LayoutEvent.REQUEST = 'layout.request';
|
|
4816
4818
|
LayoutEvent.START = 'layout.start';
|
|
4817
4819
|
LayoutEvent.BEFORE = 'layout.before';
|
|
@@ -5006,13 +5008,13 @@ var LeaferUI = (function (exports) {
|
|
|
5006
5008
|
const LeafEventer = { on, on_, off, off_, once, emit: emit$2, emitEvent: emitEvent$1, hasEvent, destroyEventer: destroy };
|
|
5007
5009
|
|
|
5008
5010
|
const { isFinite } = Number;
|
|
5009
|
-
const debug$
|
|
5011
|
+
const debug$7 = Debug.get('setAttr');
|
|
5010
5012
|
const LeafDataProxy = {
|
|
5011
5013
|
__setAttr(name, newValue, checkFiniteNumber) {
|
|
5012
5014
|
if (this.leaferIsCreated) {
|
|
5013
5015
|
const oldValue = this.__.__getInput(name);
|
|
5014
5016
|
if (checkFiniteNumber && !isFinite(newValue) && newValue !== undefined) {
|
|
5015
|
-
debug$
|
|
5017
|
+
debug$7.warn(this.innerName, name, newValue);
|
|
5016
5018
|
newValue = undefined;
|
|
5017
5019
|
}
|
|
5018
5020
|
if (typeof newValue === 'object' || oldValue !== newValue) {
|
|
@@ -5082,7 +5084,7 @@ var LeaferUI = (function (exports) {
|
|
|
5082
5084
|
const { updateMatrix: updateMatrix$1, updateAllMatrix: updateAllMatrix$2 } = LeafHelper;
|
|
5083
5085
|
const { updateBounds: updateBounds$1 } = BranchHelper;
|
|
5084
5086
|
const { toOuterOf: toOuterOf$1, copyAndSpread: copyAndSpread$1, copy: copy$5 } = BoundsHelper;
|
|
5085
|
-
const { toBounds: toBounds$
|
|
5087
|
+
const { toBounds: toBounds$1 } = PathBounds;
|
|
5086
5088
|
const LeafBounds = {
|
|
5087
5089
|
__updateWorldBounds() {
|
|
5088
5090
|
toOuterOf$1(this.__layout.renderBounds, this.__world, this.__world);
|
|
@@ -5164,7 +5166,7 @@ var LeaferUI = (function (exports) {
|
|
|
5164
5166
|
const b = this.__layout.boxBounds;
|
|
5165
5167
|
const data = this.__;
|
|
5166
5168
|
if (data.__pathInputed) {
|
|
5167
|
-
toBounds$
|
|
5169
|
+
toBounds$1(data.path, b);
|
|
5168
5170
|
}
|
|
5169
5171
|
else {
|
|
5170
5172
|
b.x = 0;
|
|
@@ -5712,7 +5714,7 @@ var LeaferUI = (function (exports) {
|
|
|
5712
5714
|
const { setListWithFn } = BoundsHelper;
|
|
5713
5715
|
const { sort } = BranchHelper;
|
|
5714
5716
|
const { localBoxBounds, localStrokeBounds, localRenderBounds, maskLocalBoxBounds, maskLocalStrokeBounds, maskLocalRenderBounds } = LeafBoundsHelper;
|
|
5715
|
-
const debug$
|
|
5717
|
+
const debug$6 = new Debug('Branch');
|
|
5716
5718
|
exports.Branch = class Branch extends exports.Leaf {
|
|
5717
5719
|
__updateStrokeSpread() {
|
|
5718
5720
|
const { children } = this;
|
|
@@ -5754,7 +5756,7 @@ var LeaferUI = (function (exports) {
|
|
|
5754
5756
|
}
|
|
5755
5757
|
add(child, index) {
|
|
5756
5758
|
if (child === this || child.destroyed)
|
|
5757
|
-
return debug$
|
|
5759
|
+
return debug$6.warn('add self or destroyed');
|
|
5758
5760
|
const noIndex = index === undefined;
|
|
5759
5761
|
if (!child.__) {
|
|
5760
5762
|
if (child instanceof Array)
|
|
@@ -6008,9 +6010,9 @@ var LeaferUI = (function (exports) {
|
|
|
6008
6010
|
}
|
|
6009
6011
|
}
|
|
6010
6012
|
|
|
6011
|
-
const version = "1.
|
|
6013
|
+
const version = "1.3.0";
|
|
6012
6014
|
|
|
6013
|
-
const debug$
|
|
6015
|
+
const debug$5 = Debug.get('LeaferCanvas');
|
|
6014
6016
|
class LeaferCanvas extends LeaferCanvasBase {
|
|
6015
6017
|
set zIndex(zIndex) {
|
|
6016
6018
|
const { style } = this.view;
|
|
@@ -6082,7 +6084,7 @@ var LeaferUI = (function (exports) {
|
|
|
6082
6084
|
}
|
|
6083
6085
|
}
|
|
6084
6086
|
else {
|
|
6085
|
-
debug$
|
|
6087
|
+
debug$5.error(`no id: ${inputView}`);
|
|
6086
6088
|
this.__createView();
|
|
6087
6089
|
}
|
|
6088
6090
|
}
|
|
@@ -6120,7 +6122,7 @@ var LeaferUI = (function (exports) {
|
|
|
6120
6122
|
}
|
|
6121
6123
|
else {
|
|
6122
6124
|
this.checkAutoBounds(this.view);
|
|
6123
|
-
debug$
|
|
6125
|
+
debug$5.warn('no parent');
|
|
6124
6126
|
}
|
|
6125
6127
|
}
|
|
6126
6128
|
catch (_a) {
|
|
@@ -6456,7 +6458,7 @@ var LeaferUI = (function (exports) {
|
|
|
6456
6458
|
}
|
|
6457
6459
|
|
|
6458
6460
|
const { updateAllMatrix, updateAllChange } = LeafHelper;
|
|
6459
|
-
const debug$
|
|
6461
|
+
const debug$4 = Debug.get('Layouter');
|
|
6460
6462
|
class Layouter {
|
|
6461
6463
|
constructor(target, userConfig) {
|
|
6462
6464
|
this.totalTimes = 0;
|
|
@@ -6491,7 +6493,7 @@ var LeaferUI = (function (exports) {
|
|
|
6491
6493
|
target.emitEvent(new LayoutEvent(LayoutEvent.END, this.layoutedBlocks, this.times));
|
|
6492
6494
|
}
|
|
6493
6495
|
catch (e) {
|
|
6494
|
-
debug$
|
|
6496
|
+
debug$4.error(e);
|
|
6495
6497
|
}
|
|
6496
6498
|
this.layoutedBlocks = null;
|
|
6497
6499
|
}
|
|
@@ -6505,9 +6507,9 @@ var LeaferUI = (function (exports) {
|
|
|
6505
6507
|
}
|
|
6506
6508
|
layoutOnce() {
|
|
6507
6509
|
if (this.layouting)
|
|
6508
|
-
return debug$
|
|
6510
|
+
return debug$4.warn('layouting');
|
|
6509
6511
|
if (this.times > 3)
|
|
6510
|
-
return debug$
|
|
6512
|
+
return debug$4.warn('layout max times');
|
|
6511
6513
|
this.times++;
|
|
6512
6514
|
this.totalTimes++;
|
|
6513
6515
|
this.layouting = true;
|
|
@@ -6611,7 +6613,7 @@ var LeaferUI = (function (exports) {
|
|
|
6611
6613
|
}
|
|
6612
6614
|
}
|
|
6613
6615
|
|
|
6614
|
-
const debug$
|
|
6616
|
+
const debug$3 = Debug.get('Renderer');
|
|
6615
6617
|
class Renderer {
|
|
6616
6618
|
get needFill() { return !!(!this.canvas.allowBackgroundColor && this.config.fill); }
|
|
6617
6619
|
constructor(target, canvas, userConfig) {
|
|
@@ -6649,7 +6651,7 @@ var LeaferUI = (function (exports) {
|
|
|
6649
6651
|
const { target } = this;
|
|
6650
6652
|
this.times = 0;
|
|
6651
6653
|
this.totalBounds = new Bounds();
|
|
6652
|
-
debug$
|
|
6654
|
+
debug$3.log(target.innerName, '--->');
|
|
6653
6655
|
try {
|
|
6654
6656
|
if (!target.isApp)
|
|
6655
6657
|
target.app.emit(RenderEvent.CHILD_START, target);
|
|
@@ -6660,9 +6662,9 @@ var LeaferUI = (function (exports) {
|
|
|
6660
6662
|
}
|
|
6661
6663
|
catch (e) {
|
|
6662
6664
|
this.rendering = false;
|
|
6663
|
-
debug$
|
|
6665
|
+
debug$3.error(e);
|
|
6664
6666
|
}
|
|
6665
|
-
debug$
|
|
6667
|
+
debug$3.log('-------------|');
|
|
6666
6668
|
}
|
|
6667
6669
|
renderAgain() {
|
|
6668
6670
|
if (this.rendering) {
|
|
@@ -6674,9 +6676,9 @@ var LeaferUI = (function (exports) {
|
|
|
6674
6676
|
}
|
|
6675
6677
|
renderOnce(callback) {
|
|
6676
6678
|
if (this.rendering)
|
|
6677
|
-
return debug$
|
|
6679
|
+
return debug$3.warn('rendering');
|
|
6678
6680
|
if (this.times > 3)
|
|
6679
|
-
return debug$
|
|
6681
|
+
return debug$3.warn('render max times');
|
|
6680
6682
|
this.times++;
|
|
6681
6683
|
this.totalTimes++;
|
|
6682
6684
|
this.rendering = true;
|
|
@@ -6713,7 +6715,7 @@ var LeaferUI = (function (exports) {
|
|
|
6713
6715
|
partRender() {
|
|
6714
6716
|
const { canvas, updateBlocks: list } = this;
|
|
6715
6717
|
if (!list)
|
|
6716
|
-
return debug$
|
|
6718
|
+
return debug$3.warn('PartRender: need update attr');
|
|
6717
6719
|
this.mergeBlocks();
|
|
6718
6720
|
list.forEach(block => { if (canvas.bounds.hit(block) && !block.isEmpty())
|
|
6719
6721
|
this.clipRender(block); });
|
|
@@ -6816,7 +6818,7 @@ var LeaferUI = (function (exports) {
|
|
|
6816
6818
|
empty = (!leaf.__world.width || !leaf.__world.height);
|
|
6817
6819
|
if (empty) {
|
|
6818
6820
|
if (!leaf.isLeafer)
|
|
6819
|
-
debug$
|
|
6821
|
+
debug$3.tip(leaf.innerName, ': empty');
|
|
6820
6822
|
empty = (!leaf.isBranch || leaf.isBranchLeaf);
|
|
6821
6823
|
}
|
|
6822
6824
|
return empty;
|
|
@@ -6982,143 +6984,26 @@ var LeaferUI = (function (exports) {
|
|
|
6982
6984
|
}
|
|
6983
6985
|
}
|
|
6984
6986
|
|
|
6985
|
-
const { Yes, NoAndSkip, YesAndSkip } = exports.Answer;
|
|
6986
|
-
const idCondition = {}, classNameCondition = {}, tagCondition = {};
|
|
6987
6987
|
class Selector {
|
|
6988
6988
|
constructor(target, userConfig) {
|
|
6989
6989
|
this.config = {};
|
|
6990
|
-
this.innerIdMap = {};
|
|
6991
|
-
this.idMap = {};
|
|
6992
|
-
this.methods = {
|
|
6993
|
-
id: (leaf, name) => leaf.id === name ? (this.target && (this.idMap[name] = leaf), 1) : 0,
|
|
6994
|
-
innerId: (leaf, innerId) => leaf.innerId === innerId ? (this.target && (this.innerIdMap[innerId] = leaf), 1) : 0,
|
|
6995
|
-
className: (leaf, name) => leaf.className === name ? 1 : 0,
|
|
6996
|
-
tag: (leaf, name) => leaf.__tag === name ? 1 : 0,
|
|
6997
|
-
tags: (leaf, nameMap) => nameMap[leaf.__tag] ? 1 : 0
|
|
6998
|
-
};
|
|
6999
|
-
this.target = target;
|
|
7000
6990
|
if (userConfig)
|
|
7001
6991
|
this.config = DataHelper.default(userConfig, this.config);
|
|
7002
|
-
this.picker = new Picker(target, this);
|
|
7003
|
-
|
|
7004
|
-
this.__listenEvents();
|
|
7005
|
-
}
|
|
7006
|
-
getBy(condition, branch, one, options) {
|
|
7007
|
-
switch (typeof condition) {
|
|
7008
|
-
case 'number':
|
|
7009
|
-
const leaf = this.getByInnerId(condition, branch);
|
|
7010
|
-
return one ? leaf : (leaf ? [leaf] : []);
|
|
7011
|
-
case 'string':
|
|
7012
|
-
switch (condition[0]) {
|
|
7013
|
-
case '#':
|
|
7014
|
-
idCondition.id = condition.substring(1), condition = idCondition;
|
|
7015
|
-
break;
|
|
7016
|
-
case '.':
|
|
7017
|
-
classNameCondition.className = condition.substring(1), condition = classNameCondition;
|
|
7018
|
-
break;
|
|
7019
|
-
default:
|
|
7020
|
-
tagCondition.tag = condition, condition = tagCondition;
|
|
7021
|
-
}
|
|
7022
|
-
case 'object':
|
|
7023
|
-
if (condition.id !== undefined) {
|
|
7024
|
-
const leaf = this.getById(condition.id, branch);
|
|
7025
|
-
return one ? leaf : (leaf ? [leaf] : []);
|
|
7026
|
-
}
|
|
7027
|
-
else if (condition.tag) {
|
|
7028
|
-
const { tag } = condition, isArray = tag instanceof Array;
|
|
7029
|
-
return this.getByMethod(isArray ? this.methods.tags : this.methods.tag, branch, one, isArray ? DataHelper.toMap(tag) : tag);
|
|
7030
|
-
}
|
|
7031
|
-
else {
|
|
7032
|
-
return this.getByMethod(this.methods.className, branch, one, condition.className);
|
|
7033
|
-
}
|
|
7034
|
-
case 'function':
|
|
7035
|
-
return this.getByMethod(condition, branch, one, options);
|
|
7036
|
-
}
|
|
6992
|
+
this.picker = new Picker(this.target = target, this);
|
|
6993
|
+
this.finder = Creator.finder && Creator.finder();
|
|
7037
6994
|
}
|
|
7038
6995
|
getByPoint(hitPoint, hitRadius, options) {
|
|
7039
|
-
if (Platform.
|
|
7040
|
-
this.target.
|
|
6996
|
+
if (Platform.backgrounder && this.target)
|
|
6997
|
+
this.target.updateLayout();
|
|
7041
6998
|
return this.picker.getByPoint(hitPoint, hitRadius, options);
|
|
7042
6999
|
}
|
|
7043
|
-
|
|
7044
|
-
|
|
7045
|
-
if (cache)
|
|
7046
|
-
return cache;
|
|
7047
|
-
this.eachFind(this.toChildren(branch), this.methods.innerId, null, innerId);
|
|
7048
|
-
return this.findLeaf;
|
|
7049
|
-
}
|
|
7050
|
-
getById(id, branch) {
|
|
7051
|
-
const cache = this.idMap[id];
|
|
7052
|
-
if (cache && LeafHelper.hasParent(cache, branch || this.target))
|
|
7053
|
-
return cache;
|
|
7054
|
-
this.eachFind(this.toChildren(branch), this.methods.id, null, id);
|
|
7055
|
-
return this.findLeaf;
|
|
7056
|
-
}
|
|
7057
|
-
getByClassName(className, branch) {
|
|
7058
|
-
return this.getByMethod(this.methods.className, branch, false, className);
|
|
7059
|
-
}
|
|
7060
|
-
getByTag(tag, branch) {
|
|
7061
|
-
return this.getByMethod(this.methods.tag, branch, false, tag);
|
|
7062
|
-
}
|
|
7063
|
-
getByMethod(method, branch, one, options) {
|
|
7064
|
-
const list = one ? null : [];
|
|
7065
|
-
this.eachFind(this.toChildren(branch), method, list, options);
|
|
7066
|
-
return list || this.findLeaf;
|
|
7067
|
-
}
|
|
7068
|
-
eachFind(children, method, list, options) {
|
|
7069
|
-
let child, result;
|
|
7070
|
-
for (let i = 0, len = children.length; i < len; i++) {
|
|
7071
|
-
child = children[i];
|
|
7072
|
-
result = method(child, options);
|
|
7073
|
-
if (result === Yes || result === YesAndSkip) {
|
|
7074
|
-
if (list) {
|
|
7075
|
-
list.push(child);
|
|
7076
|
-
}
|
|
7077
|
-
else {
|
|
7078
|
-
this.findLeaf = child;
|
|
7079
|
-
return;
|
|
7080
|
-
}
|
|
7081
|
-
}
|
|
7082
|
-
if (child.isBranch && result < NoAndSkip)
|
|
7083
|
-
this.eachFind(child.children, method, list, options);
|
|
7084
|
-
}
|
|
7085
|
-
}
|
|
7086
|
-
toChildren(branch) {
|
|
7087
|
-
this.findLeaf = null;
|
|
7088
|
-
return [branch || this.target];
|
|
7089
|
-
}
|
|
7090
|
-
__onRemoveChild(event) {
|
|
7091
|
-
const { id, innerId } = event.child;
|
|
7092
|
-
if (this.idMap[id])
|
|
7093
|
-
delete this.idMap[id];
|
|
7094
|
-
if (this.innerIdMap[innerId])
|
|
7095
|
-
delete this.innerIdMap[innerId];
|
|
7096
|
-
}
|
|
7097
|
-
__checkIdChange(event) {
|
|
7098
|
-
if (event.attrName === 'id') {
|
|
7099
|
-
const id = event.oldValue;
|
|
7100
|
-
if (this.idMap[id])
|
|
7101
|
-
delete this.idMap[id];
|
|
7102
|
-
}
|
|
7103
|
-
}
|
|
7104
|
-
__listenEvents() {
|
|
7105
|
-
this.__eventIds = [
|
|
7106
|
-
this.target.on_(ChildEvent.REMOVE, this.__onRemoveChild, this),
|
|
7107
|
-
this.target.on_(PropertyEvent.CHANGE, this.__checkIdChange, this)
|
|
7108
|
-
];
|
|
7109
|
-
}
|
|
7110
|
-
__removeListenEvents() {
|
|
7111
|
-
this.target.off_(this.__eventIds);
|
|
7112
|
-
this.__eventIds.length = 0;
|
|
7000
|
+
getBy(condition, branch, one, options) {
|
|
7001
|
+
return this.finder ? this.finder.getBy(condition, branch, one, options) : Plugin.need('find');
|
|
7113
7002
|
}
|
|
7114
7003
|
destroy() {
|
|
7115
|
-
|
|
7116
|
-
|
|
7117
|
-
this.
|
|
7118
|
-
this.findLeaf = null;
|
|
7119
|
-
this.innerIdMap = {};
|
|
7120
|
-
this.idMap = {};
|
|
7121
|
-
}
|
|
7004
|
+
this.picker.destroy();
|
|
7005
|
+
if (this.finder)
|
|
7006
|
+
this.finder.destroy();
|
|
7122
7007
|
}
|
|
7123
7008
|
}
|
|
7124
7009
|
|
|
@@ -7191,7 +7076,7 @@ var LeaferUI = (function (exports) {
|
|
|
7191
7076
|
|
|
7192
7077
|
const { parse, objectToCanvasData } = PathConvert;
|
|
7193
7078
|
const emptyPaint = {};
|
|
7194
|
-
const debug$
|
|
7079
|
+
const debug$2 = Debug.get('UIData');
|
|
7195
7080
|
class UIData extends LeafData {
|
|
7196
7081
|
get scale() { const { scaleX, scaleY } = this; return scaleX !== scaleY ? { x: scaleX, y: scaleY } : scaleX; }
|
|
7197
7082
|
get __strokeWidth() {
|
|
@@ -7228,7 +7113,7 @@ var LeaferUI = (function (exports) {
|
|
|
7228
7113
|
if (value < 0) {
|
|
7229
7114
|
this._width = -value;
|
|
7230
7115
|
this.__leaf.scaleX *= -1;
|
|
7231
|
-
debug$
|
|
7116
|
+
debug$2.warn('width < 0, instead -scaleX ', this);
|
|
7232
7117
|
}
|
|
7233
7118
|
else
|
|
7234
7119
|
this._width = value;
|
|
@@ -7237,7 +7122,7 @@ var LeaferUI = (function (exports) {
|
|
|
7237
7122
|
if (value < 0) {
|
|
7238
7123
|
this._height = -value;
|
|
7239
7124
|
this.__leaf.scaleY *= -1;
|
|
7240
|
-
debug$
|
|
7125
|
+
debug$2.warn('height < 0, instead -scaleY', this);
|
|
7241
7126
|
}
|
|
7242
7127
|
else
|
|
7243
7128
|
this._height = value;
|
|
@@ -7614,25 +7499,27 @@ var LeaferUI = (function (exports) {
|
|
|
7614
7499
|
}
|
|
7615
7500
|
reset(_data) { }
|
|
7616
7501
|
set(data, transition) {
|
|
7617
|
-
if (
|
|
7618
|
-
if (transition
|
|
7619
|
-
|
|
7620
|
-
|
|
7621
|
-
|
|
7502
|
+
if (data) {
|
|
7503
|
+
if (transition) {
|
|
7504
|
+
if (transition === 'temp') {
|
|
7505
|
+
this.lockNormalStyle = true;
|
|
7506
|
+
Object.assign(this, data);
|
|
7507
|
+
this.lockNormalStyle = false;
|
|
7508
|
+
}
|
|
7509
|
+
else
|
|
7510
|
+
this.animate(data, transition);
|
|
7622
7511
|
}
|
|
7623
7512
|
else
|
|
7624
|
-
|
|
7513
|
+
Object.assign(this, data);
|
|
7625
7514
|
}
|
|
7626
|
-
else
|
|
7627
|
-
Object.assign(this, data);
|
|
7628
7515
|
}
|
|
7629
7516
|
get(name) {
|
|
7630
7517
|
return typeof name === 'string' ? this.__.__getInput(name) : this.__.__getInputData(name);
|
|
7631
7518
|
}
|
|
7632
7519
|
createProxyData() { return undefined; }
|
|
7633
|
-
find(_condition, _options) { return
|
|
7520
|
+
find(_condition, _options) { return Plugin.need('find'); }
|
|
7634
7521
|
findTag(tag) { return this.find({ tag }); }
|
|
7635
|
-
findOne(_condition, _options) { return
|
|
7522
|
+
findOne(_condition, _options) { return Plugin.need('find'); }
|
|
7636
7523
|
findId(id) { return this.findOne({ id }); }
|
|
7637
7524
|
getPath(curve, pathForRender) {
|
|
7638
7525
|
this.__layout.update();
|
|
@@ -7684,9 +7571,9 @@ var LeaferUI = (function (exports) {
|
|
|
7684
7571
|
animate(_keyframe, _options, _type, _isTemp) {
|
|
7685
7572
|
return Plugin.need('animate');
|
|
7686
7573
|
}
|
|
7687
|
-
killAnimate(_type) { }
|
|
7688
|
-
export(
|
|
7689
|
-
return
|
|
7574
|
+
killAnimate(_type, _killStyle) { }
|
|
7575
|
+
export(_filename, _options) {
|
|
7576
|
+
return Plugin.need('export');
|
|
7690
7577
|
}
|
|
7691
7578
|
clone(data) {
|
|
7692
7579
|
const json = this.toJSON();
|
|
@@ -7932,16 +7819,18 @@ var LeaferUI = (function (exports) {
|
|
|
7932
7819
|
this.children = [];
|
|
7933
7820
|
}
|
|
7934
7821
|
set(data, transition) {
|
|
7935
|
-
if (data
|
|
7936
|
-
|
|
7937
|
-
|
|
7938
|
-
|
|
7939
|
-
|
|
7940
|
-
|
|
7941
|
-
|
|
7822
|
+
if (data) {
|
|
7823
|
+
if (data.children) {
|
|
7824
|
+
const { children } = data;
|
|
7825
|
+
delete data.children;
|
|
7826
|
+
this.children ? this.clear() : this.__setBranch();
|
|
7827
|
+
super.set(data, transition);
|
|
7828
|
+
children.forEach(child => this.add(child));
|
|
7829
|
+
data.children = children;
|
|
7830
|
+
}
|
|
7831
|
+
else
|
|
7832
|
+
super.set(data, transition);
|
|
7942
7833
|
}
|
|
7943
|
-
else
|
|
7944
|
-
super.set(data, transition);
|
|
7945
7834
|
}
|
|
7946
7835
|
toJSON(options) {
|
|
7947
7836
|
const data = super.toJSON(options);
|
|
@@ -7973,7 +7862,7 @@ var LeaferUI = (function (exports) {
|
|
|
7973
7862
|
], exports.Group);
|
|
7974
7863
|
|
|
7975
7864
|
var Leafer_1;
|
|
7976
|
-
const debug$
|
|
7865
|
+
const debug$1 = Debug.get('Leafer');
|
|
7977
7866
|
exports.Leafer = Leafer_1 = class Leafer extends exports.Group {
|
|
7978
7867
|
get __tag() { return 'Leafer'; }
|
|
7979
7868
|
get isApp() { return false; }
|
|
@@ -8138,7 +8027,7 @@ var LeaferUI = (function (exports) {
|
|
|
8138
8027
|
if (this.canvas) {
|
|
8139
8028
|
if (canvasSizeAttrs.includes(attrName)) {
|
|
8140
8029
|
if (!newValue)
|
|
8141
|
-
debug$
|
|
8030
|
+
debug$1.warn(attrName + ' is 0');
|
|
8142
8031
|
this.__changeCanvasSize(attrName, newValue);
|
|
8143
8032
|
}
|
|
8144
8033
|
else if (attrName === 'fill') {
|
|
@@ -8279,9 +8168,6 @@ var LeaferUI = (function (exports) {
|
|
|
8279
8168
|
this.canvas && this.canvas.updateClientBounds();
|
|
8280
8169
|
}
|
|
8281
8170
|
receiveEvent(_event) { }
|
|
8282
|
-
__checkUpdateLayout() {
|
|
8283
|
-
this.__layout.update();
|
|
8284
|
-
}
|
|
8285
8171
|
emitLeafer(type) {
|
|
8286
8172
|
this.emitEvent(new LeaferEvent(type, this));
|
|
8287
8173
|
}
|
|
@@ -8292,7 +8178,7 @@ var LeaferUI = (function (exports) {
|
|
|
8292
8178
|
this.once(LayoutEvent.END, () => this.__onReady());
|
|
8293
8179
|
this.once(RenderEvent.START, () => this.__onCreated());
|
|
8294
8180
|
this.once(RenderEvent.END, () => this.__onViewReady());
|
|
8295
|
-
this.__eventIds.push(this.on_(WatchEvent.DATA, this.__onWatchData, this), this.on_(RenderEvent.NEXT, this.__onNextRender, this)
|
|
8181
|
+
this.__eventIds.push(this.on_(WatchEvent.DATA, this.__onWatchData, this), this.on_(RenderEvent.NEXT, this.__onNextRender, this));
|
|
8296
8182
|
}
|
|
8297
8183
|
__removeListenEvents() {
|
|
8298
8184
|
this.off_(this.__eventIds);
|
|
@@ -8323,7 +8209,7 @@ var LeaferUI = (function (exports) {
|
|
|
8323
8209
|
setTimeout(() => { ImageManager.clearRecycled(); }, 100);
|
|
8324
8210
|
}
|
|
8325
8211
|
catch (e) {
|
|
8326
|
-
debug$
|
|
8212
|
+
debug$1.error(e);
|
|
8327
8213
|
}
|
|
8328
8214
|
}
|
|
8329
8215
|
};
|
|
@@ -8357,7 +8243,7 @@ var LeaferUI = (function (exports) {
|
|
|
8357
8243
|
], exports.Rect);
|
|
8358
8244
|
|
|
8359
8245
|
const { copy: copy$3, add, includes: includes$1 } = BoundsHelper;
|
|
8360
|
-
const rect$1 = exports.Rect.prototype, group
|
|
8246
|
+
const rect$1 = exports.Rect.prototype, group = exports.Group.prototype;
|
|
8361
8247
|
const childrenRenderBounds = {};
|
|
8362
8248
|
exports.Box = class Box extends exports.Group {
|
|
8363
8249
|
get __tag() { return 'Box'; }
|
|
@@ -8467,7 +8353,7 @@ var LeaferUI = (function (exports) {
|
|
|
8467
8353
|
rewrite(rect$1.__render)
|
|
8468
8354
|
], exports.Box.prototype, "__renderRect", null);
|
|
8469
8355
|
__decorate([
|
|
8470
|
-
rewrite(group
|
|
8356
|
+
rewrite(group.__render)
|
|
8471
8357
|
], exports.Box.prototype, "__renderGroup", null);
|
|
8472
8358
|
exports.Box = __decorate([
|
|
8473
8359
|
rewriteAble(),
|
|
@@ -8552,7 +8438,7 @@ var LeaferUI = (function (exports) {
|
|
|
8552
8438
|
|
|
8553
8439
|
const { moveTo: moveTo$2, lineTo: lineTo$2, drawPoints: drawPoints$1 } = PathCommandDataHelper;
|
|
8554
8440
|
const { rotate: rotate$1, getAngle: getAngle$1, getDistance: getDistance$2, defaultPoint } = PointHelper;
|
|
8555
|
-
const { toBounds
|
|
8441
|
+
const { toBounds } = PathBounds;
|
|
8556
8442
|
exports.Line = class Line extends exports.UI {
|
|
8557
8443
|
get __tag() { return 'Line'; }
|
|
8558
8444
|
get toPoint() {
|
|
@@ -8596,7 +8482,7 @@ var LeaferUI = (function (exports) {
|
|
|
8596
8482
|
}
|
|
8597
8483
|
__updateBoxBounds() {
|
|
8598
8484
|
if (this.points) {
|
|
8599
|
-
toBounds
|
|
8485
|
+
toBounds(this.__.__pathForRender, this.__layout.boxBounds);
|
|
8600
8486
|
}
|
|
8601
8487
|
else
|
|
8602
8488
|
super.__updateBoxBounds();
|
|
@@ -8948,6 +8834,9 @@ var LeaferUI = (function (exports) {
|
|
|
8948
8834
|
__decorate([
|
|
8949
8835
|
boundsType(0)
|
|
8950
8836
|
], exports.Text.prototype, "paraSpacing", void 0);
|
|
8837
|
+
__decorate([
|
|
8838
|
+
boundsType('x')
|
|
8839
|
+
], exports.Text.prototype, "writingMode", void 0);
|
|
8951
8840
|
__decorate([
|
|
8952
8841
|
boundsType('left')
|
|
8953
8842
|
], exports.Text.prototype, "textAlign", void 0);
|
|
@@ -9134,8 +9023,8 @@ var LeaferUI = (function (exports) {
|
|
|
9134
9023
|
this.children.forEach(leafer => leafer.resize(event));
|
|
9135
9024
|
super.__onResize(event);
|
|
9136
9025
|
}
|
|
9137
|
-
|
|
9138
|
-
this.children.forEach(leafer => leafer.
|
|
9026
|
+
updateLayout() {
|
|
9027
|
+
this.children.forEach(leafer => leafer.updateLayout());
|
|
9139
9028
|
}
|
|
9140
9029
|
__getChildConfig(userConfig) {
|
|
9141
9030
|
let config = Object.assign({}, this.config);
|
|
@@ -9625,7 +9514,7 @@ var LeaferUI = (function (exports) {
|
|
|
9625
9514
|
}
|
|
9626
9515
|
}
|
|
9627
9516
|
|
|
9628
|
-
const debug
|
|
9517
|
+
const debug = Debug.get('emit');
|
|
9629
9518
|
function emit$1(type, data, path, excludePath) {
|
|
9630
9519
|
if (!path && !data.path)
|
|
9631
9520
|
return;
|
|
@@ -9655,7 +9544,7 @@ var LeaferUI = (function (exports) {
|
|
|
9655
9544
|
}
|
|
9656
9545
|
}
|
|
9657
9546
|
catch (e) {
|
|
9658
|
-
debug
|
|
9547
|
+
debug.error(e);
|
|
9659
9548
|
}
|
|
9660
9549
|
}
|
|
9661
9550
|
const allowTypes = ['move', 'zoom', 'rotate', 'key'];
|
|
@@ -10212,8 +10101,8 @@ var LeaferUI = (function (exports) {
|
|
|
10212
10101
|
this.__drawRenderPath(canvas); };
|
|
10213
10102
|
|
|
10214
10103
|
const matrix = new Matrix();
|
|
10215
|
-
const ui$
|
|
10216
|
-
ui$
|
|
10104
|
+
const ui$1 = exports.UI.prototype;
|
|
10105
|
+
ui$1.__updateHitCanvas = function () {
|
|
10217
10106
|
const data = this.__, { hitCanvasManager } = this.leafer;
|
|
10218
10107
|
const isHitPixelFill = (data.__pixelFill || data.__isCanvas) && data.hitFill === 'pixel';
|
|
10219
10108
|
const isHitPixelStroke = data.__pixelStroke && data.hitStroke === 'pixel';
|
|
@@ -10240,7 +10129,7 @@ var LeaferUI = (function (exports) {
|
|
|
10240
10129
|
this.__drawHitPath(h);
|
|
10241
10130
|
h.setStrokeOptions(data);
|
|
10242
10131
|
};
|
|
10243
|
-
ui$
|
|
10132
|
+
ui$1.__hit = function (inner) {
|
|
10244
10133
|
if (Platform.name === 'miniapp')
|
|
10245
10134
|
this.__drawHitPath(this.__hitCanvas);
|
|
10246
10135
|
const data = this.__;
|
|
@@ -10280,43 +10169,35 @@ var LeaferUI = (function (exports) {
|
|
|
10280
10169
|
return hitWidth ? this.__hitStroke(inner, hitWidth) : false;
|
|
10281
10170
|
};
|
|
10282
10171
|
|
|
10283
|
-
const ui
|
|
10172
|
+
const ui = exports.UI.prototype, rect = exports.Rect.prototype, box$1 = exports.Box.prototype;
|
|
10284
10173
|
rect.__updateHitCanvas = box$1.__updateHitCanvas = function () {
|
|
10285
10174
|
if (this.stroke || this.cornerRadius || ((this.fill || this.__.__isCanvas) && this.hitFill === 'pixel') || this.hitStroke === 'all')
|
|
10286
|
-
ui
|
|
10175
|
+
ui.__updateHitCanvas.call(this);
|
|
10287
10176
|
else if (this.__hitCanvas)
|
|
10288
10177
|
this.__hitCanvas = null;
|
|
10289
10178
|
};
|
|
10290
10179
|
rect.__hitFill = box$1.__hitFill = function (inner) {
|
|
10291
|
-
return this.__hitCanvas ? ui
|
|
10180
|
+
return this.__hitCanvas ? ui.__hitFill.call(this, inner) : BoundsHelper.hitRadiusPoint(this.__layout.boxBounds, inner);
|
|
10292
10181
|
};
|
|
10293
10182
|
|
|
10294
|
-
const ui = exports.UI.prototype, group = exports.Group.prototype;
|
|
10295
10183
|
function getSelector(ui) {
|
|
10296
10184
|
return ui.leafer ? ui.leafer.selector : (Platform.selector || (Platform.selector = Creator.selector()));
|
|
10297
10185
|
}
|
|
10298
|
-
|
|
10299
|
-
|
|
10300
|
-
|
|
10301
|
-
ui.findOne = function (condition, options) {
|
|
10302
|
-
return getSelector(this).getBy(condition, this, true, options);
|
|
10303
|
-
};
|
|
10304
|
-
group.pick = function (hitPoint, options) {
|
|
10305
|
-
this.__layout.update();
|
|
10306
|
-
if (!options)
|
|
10307
|
-
options = {};
|
|
10186
|
+
exports.Group.prototype.pick = function (hitPoint, options) {
|
|
10187
|
+
this.leafer || this.updateLayout();
|
|
10188
|
+
options || (options = emptyData);
|
|
10308
10189
|
return getSelector(this).getByPoint(hitPoint, options.hitRadius || 0, Object.assign(Object.assign({}, options), { target: this }));
|
|
10309
10190
|
};
|
|
10310
10191
|
|
|
10311
|
-
const canvas
|
|
10312
|
-
canvas
|
|
10192
|
+
const canvas = LeaferCanvasBase.prototype;
|
|
10193
|
+
canvas.hitFill = function (point, fillRule) {
|
|
10313
10194
|
return fillRule ? this.context.isPointInPath(point.x, point.y, fillRule) : this.context.isPointInPath(point.x, point.y);
|
|
10314
10195
|
};
|
|
10315
|
-
canvas
|
|
10196
|
+
canvas.hitStroke = function (point, strokeWidth) {
|
|
10316
10197
|
this.strokeWidth = strokeWidth;
|
|
10317
10198
|
return this.context.isPointInStroke(point.x, point.y);
|
|
10318
10199
|
};
|
|
10319
|
-
canvas
|
|
10200
|
+
canvas.hitPixel = function (radiusPoint, offset, scale = 1) {
|
|
10320
10201
|
let { x, y, radiusX, radiusY } = radiusPoint;
|
|
10321
10202
|
if (offset)
|
|
10322
10203
|
x -= offset.x, y -= offset.y;
|
|
@@ -12112,197 +11993,12 @@ var LeaferUI = (function (exports) {
|
|
|
12112
11993
|
string
|
|
12113
11994
|
};
|
|
12114
11995
|
|
|
12115
|
-
const { setPoint, addPoint, toBounds } = TwoPointBoundsHelper;
|
|
12116
|
-
function getTrimBounds(canvas) {
|
|
12117
|
-
const { width, height } = canvas.view;
|
|
12118
|
-
const { data } = canvas.context.getImageData(0, 0, width, height);
|
|
12119
|
-
let x, y, pointBounds, index = 0;
|
|
12120
|
-
for (let i = 0; i < data.length; i += 4) {
|
|
12121
|
-
if (data[i + 3] !== 0) {
|
|
12122
|
-
x = index % width;
|
|
12123
|
-
y = (index - x) / width;
|
|
12124
|
-
pointBounds ? addPoint(pointBounds, x, y) : setPoint(pointBounds = {}, x, y);
|
|
12125
|
-
}
|
|
12126
|
-
index++;
|
|
12127
|
-
}
|
|
12128
|
-
const bounds = new Bounds();
|
|
12129
|
-
toBounds(pointBounds, bounds);
|
|
12130
|
-
return bounds.scale(1 / canvas.pixelRatio).ceil();
|
|
12131
|
-
}
|
|
12132
|
-
|
|
12133
|
-
const ExportModule = {
|
|
12134
|
-
export(leaf, filename, options) {
|
|
12135
|
-
this.running = true;
|
|
12136
|
-
const fileType = FileHelper.fileType(filename);
|
|
12137
|
-
const isDownload = filename.includes('.');
|
|
12138
|
-
options = FileHelper.getExportOptions(options);
|
|
12139
|
-
return addTask((success) => new Promise((resolve) => {
|
|
12140
|
-
const over = (result) => {
|
|
12141
|
-
success(result);
|
|
12142
|
-
resolve();
|
|
12143
|
-
this.running = false;
|
|
12144
|
-
};
|
|
12145
|
-
const { toURL } = Platform;
|
|
12146
|
-
const { download } = Platform.origin;
|
|
12147
|
-
if (fileType === 'json') {
|
|
12148
|
-
isDownload && download(toURL(JSON.stringify(leaf.toJSON(options.json)), 'text'), filename);
|
|
12149
|
-
return over({ data: isDownload ? true : leaf.toJSON(options.json) });
|
|
12150
|
-
}
|
|
12151
|
-
if (fileType === 'svg') {
|
|
12152
|
-
isDownload && download(toURL(leaf.toSVG(), 'svg'), filename);
|
|
12153
|
-
return over({ data: isDownload ? true : leaf.toSVG() });
|
|
12154
|
-
}
|
|
12155
|
-
const { leafer } = leaf;
|
|
12156
|
-
if (leafer) {
|
|
12157
|
-
checkLazy(leaf);
|
|
12158
|
-
leafer.waitViewCompleted(() => __awaiter(this, void 0, void 0, function* () {
|
|
12159
|
-
let renderBounds, trimBounds, scaleX = 1, scaleY = 1;
|
|
12160
|
-
const { worldTransform, isLeafer, isFrame } = leaf;
|
|
12161
|
-
const { slice, trim, onCanvas } = options;
|
|
12162
|
-
const smooth = options.smooth === undefined ? leafer.config.smooth : options.smooth;
|
|
12163
|
-
const contextSettings = options.contextSettings || leafer.config.contextSettings;
|
|
12164
|
-
const screenshot = options.screenshot || leaf.isApp;
|
|
12165
|
-
const fill = (isLeafer && screenshot) ? (options.fill === undefined ? leaf.fill : options.fill) : options.fill;
|
|
12166
|
-
const needFill = FileHelper.isOpaqueImage(filename) || fill, matrix = new Matrix();
|
|
12167
|
-
if (screenshot) {
|
|
12168
|
-
renderBounds = screenshot === true ? (isLeafer ? leafer.canvas.bounds : leaf.worldRenderBounds) : screenshot;
|
|
12169
|
-
}
|
|
12170
|
-
else {
|
|
12171
|
-
let relative = options.relative || (isLeafer ? 'inner' : 'local');
|
|
12172
|
-
scaleX = worldTransform.scaleX;
|
|
12173
|
-
scaleY = worldTransform.scaleY;
|
|
12174
|
-
switch (relative) {
|
|
12175
|
-
case 'inner':
|
|
12176
|
-
matrix.set(worldTransform);
|
|
12177
|
-
break;
|
|
12178
|
-
case 'local':
|
|
12179
|
-
matrix.set(worldTransform).divide(leaf.localTransform);
|
|
12180
|
-
scaleX /= leaf.scaleX;
|
|
12181
|
-
scaleY /= leaf.scaleY;
|
|
12182
|
-
break;
|
|
12183
|
-
case 'world':
|
|
12184
|
-
scaleX = 1;
|
|
12185
|
-
scaleY = 1;
|
|
12186
|
-
break;
|
|
12187
|
-
case 'page':
|
|
12188
|
-
relative = leaf.leafer;
|
|
12189
|
-
default:
|
|
12190
|
-
matrix.set(worldTransform).divide(leaf.getTransform(relative));
|
|
12191
|
-
const l = relative.worldTransform;
|
|
12192
|
-
scaleX /= scaleX / l.scaleX;
|
|
12193
|
-
scaleY /= scaleY / l.scaleY;
|
|
12194
|
-
}
|
|
12195
|
-
renderBounds = leaf.getBounds('render', relative);
|
|
12196
|
-
}
|
|
12197
|
-
const scaleData = { scaleX: 1, scaleY: 1 };
|
|
12198
|
-
MathHelper.getScaleData(options.scale, options.size, renderBounds, scaleData);
|
|
12199
|
-
let pixelRatio = options.pixelRatio || 1;
|
|
12200
|
-
if (leaf.isApp) {
|
|
12201
|
-
scaleData.scaleX *= pixelRatio;
|
|
12202
|
-
scaleData.scaleY *= pixelRatio;
|
|
12203
|
-
pixelRatio = leaf.app.pixelRatio;
|
|
12204
|
-
}
|
|
12205
|
-
const { x, y, width, height } = new Bounds(renderBounds).scale(scaleData.scaleX, scaleData.scaleY);
|
|
12206
|
-
const renderOptions = { matrix: matrix.scale(1 / scaleData.scaleX, 1 / scaleData.scaleY).invert().translate(-x, -y).withScale(1 / scaleX * scaleData.scaleX, 1 / scaleY * scaleData.scaleY) };
|
|
12207
|
-
let canvas = Creator.canvas({ width: Math.round(width), height: Math.round(height), pixelRatio, smooth, contextSettings });
|
|
12208
|
-
let sliceLeaf;
|
|
12209
|
-
if (slice) {
|
|
12210
|
-
sliceLeaf = leaf;
|
|
12211
|
-
sliceLeaf.__worldOpacity = 0;
|
|
12212
|
-
leaf = leafer;
|
|
12213
|
-
renderOptions.bounds = canvas.bounds;
|
|
12214
|
-
}
|
|
12215
|
-
canvas.save();
|
|
12216
|
-
if (isFrame && fill !== undefined) {
|
|
12217
|
-
const oldFill = leaf.get('fill');
|
|
12218
|
-
leaf.fill = '';
|
|
12219
|
-
leaf.__render(canvas, renderOptions);
|
|
12220
|
-
leaf.fill = oldFill;
|
|
12221
|
-
}
|
|
12222
|
-
else {
|
|
12223
|
-
leaf.__render(canvas, renderOptions);
|
|
12224
|
-
}
|
|
12225
|
-
canvas.restore();
|
|
12226
|
-
if (sliceLeaf)
|
|
12227
|
-
sliceLeaf.__updateWorldOpacity();
|
|
12228
|
-
if (trim) {
|
|
12229
|
-
trimBounds = getTrimBounds(canvas);
|
|
12230
|
-
const old = canvas, { width, height } = trimBounds;
|
|
12231
|
-
const config = { x: 0, y: 0, width, height, pixelRatio };
|
|
12232
|
-
canvas = Creator.canvas(config);
|
|
12233
|
-
canvas.copyWorld(old, trimBounds, config);
|
|
12234
|
-
}
|
|
12235
|
-
if (needFill)
|
|
12236
|
-
canvas.fillWorld(canvas.bounds, fill || '#FFFFFF', 'destination-over');
|
|
12237
|
-
if (onCanvas)
|
|
12238
|
-
onCanvas(canvas);
|
|
12239
|
-
const data = filename === 'canvas' ? canvas : yield canvas.export(filename, options);
|
|
12240
|
-
over({ data, width: canvas.pixelWidth, height: canvas.pixelHeight, renderBounds, trimBounds });
|
|
12241
|
-
}));
|
|
12242
|
-
}
|
|
12243
|
-
else {
|
|
12244
|
-
over({ data: false });
|
|
12245
|
-
}
|
|
12246
|
-
}));
|
|
12247
|
-
}
|
|
12248
|
-
};
|
|
12249
|
-
let tasker;
|
|
12250
|
-
function addTask(task) {
|
|
12251
|
-
if (!tasker)
|
|
12252
|
-
tasker = new TaskProcessor();
|
|
12253
|
-
return new Promise((resolve) => {
|
|
12254
|
-
tasker.add(() => __awaiter(this, void 0, void 0, function* () { return yield task(resolve); }), { parallel: false });
|
|
12255
|
-
});
|
|
12256
|
-
}
|
|
12257
|
-
function checkLazy(leaf) {
|
|
12258
|
-
if (leaf.__.__needComputePaint)
|
|
12259
|
-
leaf.__.__computePaint();
|
|
12260
|
-
if (leaf.isBranch)
|
|
12261
|
-
leaf.children.forEach(child => checkLazy(child));
|
|
12262
|
-
}
|
|
12263
|
-
|
|
12264
|
-
const canvas = LeaferCanvasBase.prototype;
|
|
12265
|
-
const debug = Debug.get('@leafer-ui/export');
|
|
12266
|
-
canvas.export = function (filename, options) {
|
|
12267
|
-
const { quality, blob } = FileHelper.getExportOptions(options);
|
|
12268
|
-
if (filename.includes('.'))
|
|
12269
|
-
return this.saveAs(filename, quality);
|
|
12270
|
-
else if (blob)
|
|
12271
|
-
return this.toBlob(filename, quality);
|
|
12272
|
-
else
|
|
12273
|
-
return this.toDataURL(filename, quality);
|
|
12274
|
-
};
|
|
12275
|
-
canvas.toBlob = function (type, quality) {
|
|
12276
|
-
return new Promise((resolve) => {
|
|
12277
|
-
Platform.origin.canvasToBolb(this.view, type, quality).then((blob) => {
|
|
12278
|
-
resolve(blob);
|
|
12279
|
-
}).catch((e) => {
|
|
12280
|
-
debug.error(e);
|
|
12281
|
-
resolve(null);
|
|
12282
|
-
});
|
|
12283
|
-
});
|
|
12284
|
-
};
|
|
12285
|
-
canvas.toDataURL = function (type, quality) {
|
|
12286
|
-
return Platform.origin.canvasToDataURL(this.view, type, quality);
|
|
12287
|
-
};
|
|
12288
|
-
canvas.saveAs = function (filename, quality) {
|
|
12289
|
-
return new Promise((resolve) => {
|
|
12290
|
-
Platform.origin.canvasSaveAs(this.view, filename, quality).then(() => {
|
|
12291
|
-
resolve(true);
|
|
12292
|
-
}).catch((e) => {
|
|
12293
|
-
debug.error(e);
|
|
12294
|
-
resolve(false);
|
|
12295
|
-
});
|
|
12296
|
-
});
|
|
12297
|
-
};
|
|
12298
|
-
|
|
12299
11996
|
Object.assign(TextConvert, TextConvertModule);
|
|
12300
11997
|
Object.assign(ColorConvert, ColorConvertModule);
|
|
12301
11998
|
Object.assign(Paint, PaintModule);
|
|
12302
11999
|
Object.assign(PaintImage, PaintImageModule);
|
|
12303
12000
|
Object.assign(PaintGradient, PaintGradientModule);
|
|
12304
12001
|
Object.assign(Effect, EffectModule);
|
|
12305
|
-
Object.assign(Export, ExportModule);
|
|
12306
12002
|
|
|
12307
12003
|
Object.assign(Creator, {
|
|
12308
12004
|
interaction: (target, canvas, selector, options) => new Interaction(target, canvas, selector, options),
|
|
@@ -12393,6 +12089,7 @@ var LeaferUI = (function (exports) {
|
|
|
12393
12089
|
exports.PathNumberCommandLengthMap = PathNumberCommandLengthMap;
|
|
12394
12090
|
exports.PathNumberCommandMap = PathNumberCommandMap;
|
|
12395
12091
|
exports.PenData = PenData;
|
|
12092
|
+
exports.Picker = Picker;
|
|
12396
12093
|
exports.Platform = Platform;
|
|
12397
12094
|
exports.Plugin = Plugin;
|
|
12398
12095
|
exports.Point = Point;
|