@hufe921/canvas-editor 0.9.129 → 0.9.131
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/CHANGELOG.md +34 -0
- package/dist/canvas-editor.es.js +105 -17
- package/dist/canvas-editor.es.js.map +1 -1
- package/dist/canvas-editor.umd.js +40 -40
- package/dist/canvas-editor.umd.js.map +1 -1
- package/dist/src/editor/core/draw/particle/block/BlockParticle.d.ts +1 -0
- package/dist/src/editor/core/worker/WorkerManager.d.ts +1 -0
- package/dist/src/editor/dataset/enum/Watermark.d.ts +4 -0
- package/dist/src/editor/index.d.ts +2 -2
- package/dist/src/editor/interface/Draw.d.ts +1 -0
- package/dist/src/editor/interface/Editor.d.ts +1 -0
- package/dist/src/editor/interface/Watermark.d.ts +2 -1
- package/dist/src/editor/utils/index.d.ts +1 -0
- package/package.json +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,3 +1,37 @@
|
|
|
1
|
+
## [0.9.131](https://github.com/Hufe921/canvas-editor/compare/v0.9.130...v0.9.131) (2026-04-10)
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
### Bug Fixes
|
|
5
|
+
|
|
6
|
+
* multiple consecutive lists rendering extra blank lines #1389 ([f344b74](https://github.com/Hufe921/canvas-editor/commit/f344b74bb342408a8f39cdae4d06782e8c5945db)), closes [#1389](https://github.com/Hufe921/canvas-editor/issues/1389)
|
|
7
|
+
* table cell adaptive row height #1388 ([8d23ce3](https://github.com/Hufe921/canvas-editor/commit/8d23ce3fa8eb8edacd0dcf4652c78eb71ded50a4)), closes [#1388](https://github.com/Hufe921/canvas-editor/issues/1388)
|
|
8
|
+
* terminate workers and disconnect observer when editor destroy ([132b992](https://github.com/Hufe921/canvas-editor/commit/132b9927df698012a46e597265fadc5ce0be56f2))
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
### Features
|
|
12
|
+
|
|
13
|
+
* add filterEmptyControl option to print mode #1385 ([81a6c86](https://github.com/Hufe921/canvas-editor/commit/81a6c86ab0736461f77b821401b08f87a06588c0)), closes [#1385](https://github.com/Hufe921/canvas-editor/issues/1385)
|
|
14
|
+
* support watermark layer configuration #1386 ([b0a068b](https://github.com/Hufe921/canvas-editor/commit/b0a068b097b9ec3a6b89b3385f0bdb589c4204f5)), closes [#1386](https://github.com/Hufe921/canvas-editor/issues/1386)
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
## [0.9.130](https://github.com/Hufe921/canvas-editor/compare/v0.9.129...v0.9.130) (2026-03-27)
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
### Bug Fixes
|
|
22
|
+
|
|
23
|
+
* correct duplicate variable check in TextParticle render ([4b72161](https://github.com/Hufe921/canvas-editor/commit/4b721618d10ef484e92b79f52ea27ee4be316814))
|
|
24
|
+
* ensure trailing line break in element list formatting #1378 ([30074b6](https://github.com/Hufe921/canvas-editor/commit/30074b6b703b3da581c5446a75edb38f4bff56b7)), closes [#1378](https://github.com/Hufe921/canvas-editor/issues/1378)
|
|
25
|
+
* optimize cursor positioning for left/right key handlers #1378 ([a79928f](https://github.com/Hufe921/canvas-editor/commit/a79928fc507cac0302e105110bc31f2baeefb74c)), closes [#1378](https://github.com/Hufe921/canvas-editor/issues/1378)
|
|
26
|
+
* prevent extra line break when list is first element in table #1381 ([bae2394](https://github.com/Hufe921/canvas-editor/commit/bae2394ceffee5e1a5b8f55d5ef8d60f7edc44b9)), closes [#1381](https://github.com/Hufe921/canvas-editor/issues/1381)
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
### Features
|
|
30
|
+
|
|
31
|
+
* support iframe snapshot in getImage api #1380 ([d980298](https://github.com/Hufe921/canvas-editor/commit/d9802988587333b8b624112f554d2b4e9d702e00)), closes [#1380](https://github.com/Hufe921/canvas-editor/issues/1380)
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
|
|
1
35
|
## [0.9.129](https://github.com/Hufe921/canvas-editor/compare/v0.9.128...v0.9.129) (2026-03-13)
|
|
2
36
|
|
|
3
37
|
|
package/dist/canvas-editor.es.js
CHANGED
|
@@ -23,7 +23,7 @@ var __publicField = (obj, key, value) => {
|
|
|
23
23
|
return value;
|
|
24
24
|
};
|
|
25
25
|
var index = "";
|
|
26
|
-
const version = "0.9.
|
|
26
|
+
const version = "0.9.131";
|
|
27
27
|
var MaxHeightRatio;
|
|
28
28
|
(function(MaxHeightRatio2) {
|
|
29
29
|
MaxHeightRatio2["HALF"] = "half";
|
|
@@ -414,6 +414,14 @@ function isRectIntersect(rect1, rect2) {
|
|
|
414
414
|
function isNonValue(value) {
|
|
415
415
|
return value === void 0 || value === null;
|
|
416
416
|
}
|
|
417
|
+
function loadImage(src) {
|
|
418
|
+
return new Promise((resolve, reject) => {
|
|
419
|
+
const img = new Image();
|
|
420
|
+
img.onload = () => resolve(img);
|
|
421
|
+
img.onerror = reject;
|
|
422
|
+
img.src = src;
|
|
423
|
+
});
|
|
424
|
+
}
|
|
417
425
|
function normalizeLineBreak(text) {
|
|
418
426
|
return text.replace(/\r\n|\r/g, "\n");
|
|
419
427
|
}
|
|
@@ -477,7 +485,8 @@ const EDITOR_CLIPBOARD = `${EDITOR_PREFIX}-clipboard`;
|
|
|
477
485
|
const defaultModeRuleOption = {
|
|
478
486
|
print: {
|
|
479
487
|
imagePreviewerDisabled: false,
|
|
480
|
-
backgroundDisabled: false
|
|
488
|
+
backgroundDisabled: false,
|
|
489
|
+
filterEmptyControl: true
|
|
481
490
|
},
|
|
482
491
|
readonly: {
|
|
483
492
|
imagePreviewerDisabled: false
|
|
@@ -4274,6 +4283,11 @@ var WatermarkType;
|
|
|
4274
4283
|
WatermarkType2["TEXT"] = "text";
|
|
4275
4284
|
WatermarkType2["IMAGE"] = "image";
|
|
4276
4285
|
})(WatermarkType || (WatermarkType = {}));
|
|
4286
|
+
var WatermarkLayer;
|
|
4287
|
+
(function(WatermarkLayer2) {
|
|
4288
|
+
WatermarkLayer2["BOTTOM"] = "bottom";
|
|
4289
|
+
WatermarkLayer2["TOP"] = "top";
|
|
4290
|
+
})(WatermarkLayer || (WatermarkLayer = {}));
|
|
4277
4291
|
const defaultWatermarkOption = {
|
|
4278
4292
|
data: "",
|
|
4279
4293
|
type: WatermarkType.TEXT,
|
|
@@ -4285,7 +4299,8 @@ const defaultWatermarkOption = {
|
|
|
4285
4299
|
font: "Microsoft YaHei",
|
|
4286
4300
|
repeat: false,
|
|
4287
4301
|
gap: [10, 10],
|
|
4288
|
-
numberType: NumberType.ARABIC
|
|
4302
|
+
numberType: NumberType.ARABIC,
|
|
4303
|
+
layer: WatermarkLayer.BOTTOM
|
|
4289
4304
|
};
|
|
4290
4305
|
const defaultZoneOption = {
|
|
4291
4306
|
tipDisabled: true
|
|
@@ -4440,10 +4455,10 @@ function unzipElementList(elementList) {
|
|
|
4440
4455
|
return result;
|
|
4441
4456
|
}
|
|
4442
4457
|
function formatElementList(elementList, options) {
|
|
4443
|
-
var _a, _b;
|
|
4458
|
+
var _a, _b, _c;
|
|
4444
4459
|
const { isHandleFirstElement = true, isForceCompensation = false, editorOptions } = options;
|
|
4445
4460
|
const startElement = elementList[0];
|
|
4446
|
-
if (
|
|
4461
|
+
if ((startElement == null ? void 0 : startElement.type) !== ElementType.LIST && (isForceCompensation || isHandleFirstElement && ((startElement == null ? void 0 : startElement.type) && startElement.type !== ElementType.TEXT || !START_LINE_BREAK_REG.test(startElement == null ? void 0 : startElement.value)))) {
|
|
4447
4462
|
elementList.unshift({
|
|
4448
4463
|
value: ZERO
|
|
4449
4464
|
});
|
|
@@ -4498,6 +4513,12 @@ function formatElementList(elementList, options) {
|
|
|
4498
4513
|
elementList.splice(i, 0, value);
|
|
4499
4514
|
i++;
|
|
4500
4515
|
}
|
|
4516
|
+
if (elementList[i] && (((_a = elementList[i].valueList) == null ? void 0 : _a.length) ? !START_LINE_BREAK_REG.test(elementList[i].valueList[0].value) : !START_LINE_BREAK_REG.test(elementList[i].value))) {
|
|
4517
|
+
elementList.splice(i, 0, {
|
|
4518
|
+
value: ZERO
|
|
4519
|
+
});
|
|
4520
|
+
i++;
|
|
4521
|
+
}
|
|
4501
4522
|
}
|
|
4502
4523
|
i--;
|
|
4503
4524
|
} else if (el.type === ElementType.AREA) {
|
|
@@ -4557,7 +4578,7 @@ function formatElementList(elementList, options) {
|
|
|
4557
4578
|
isHandleFirstElement: true,
|
|
4558
4579
|
isForceCompensation: true
|
|
4559
4580
|
}));
|
|
4560
|
-
if (!td.value[0].size && ((
|
|
4581
|
+
if (!td.value[0].size && ((_b = td.value[1]) == null ? void 0 : _b.size) && isTextLikeElement(td.value[1])) {
|
|
4561
4582
|
td.value[0].size = td.value[1].size;
|
|
4562
4583
|
}
|
|
4563
4584
|
for (let v = 0; v < td.value.length; v++) {
|
|
@@ -4787,7 +4808,7 @@ function formatElementList(elementList, options) {
|
|
|
4787
4808
|
i++;
|
|
4788
4809
|
}
|
|
4789
4810
|
i--;
|
|
4790
|
-
} else if ((!el.type || TEXTLIKE_ELEMENT_TYPE.includes(el.type)) && ((
|
|
4811
|
+
} else if ((!el.type || TEXTLIKE_ELEMENT_TYPE.includes(el.type)) && ((_c = el.value) == null ? void 0 : _c.length) > 1) {
|
|
4791
4812
|
elementList.splice(i, 1);
|
|
4792
4813
|
const valueList = splitText(el.value);
|
|
4793
4814
|
for (let v = 0; v < valueList.length; v++) {
|
|
@@ -7533,6 +7554,20 @@ function left(evt, host) {
|
|
|
7533
7554
|
isSubmitHistory: false,
|
|
7534
7555
|
isCompute: false
|
|
7535
7556
|
});
|
|
7557
|
+
if (isAnchorCollapsed) {
|
|
7558
|
+
const positionList = position.getPositionList();
|
|
7559
|
+
const anchorPosition = positionList[anchorStartIndex];
|
|
7560
|
+
if ((anchorPosition == null ? void 0 : anchorPosition.isLastLetter) && anchorPosition.value !== ZERO && anchorStartIndex + 1 < positionList.length) {
|
|
7561
|
+
const nextPosition = positionList[anchorStartIndex + 1];
|
|
7562
|
+
const element = newElementList[anchorStartIndex];
|
|
7563
|
+
const nextElement = newElementList[anchorStartIndex + 1];
|
|
7564
|
+
if (nextPosition.value !== ZERO && !getIsBlockElement(nextElement) && element.listId === nextElement.listId) {
|
|
7565
|
+
draw.getCursor().drawCursor({
|
|
7566
|
+
hitLineStartIndex: anchorStartIndex + 1
|
|
7567
|
+
});
|
|
7568
|
+
}
|
|
7569
|
+
}
|
|
7570
|
+
}
|
|
7536
7571
|
evt.preventDefault();
|
|
7537
7572
|
}
|
|
7538
7573
|
function right(evt, host) {
|
|
@@ -7677,6 +7712,19 @@ function right(evt, host) {
|
|
|
7677
7712
|
isSubmitHistory: false,
|
|
7678
7713
|
isCompute: false
|
|
7679
7714
|
});
|
|
7715
|
+
if (isAnchorCollapsed) {
|
|
7716
|
+
const anchorPosition = positionList[anchorStartIndex];
|
|
7717
|
+
if ((anchorPosition == null ? void 0 : anchorPosition.isLastLetter) && anchorPosition.value !== ZERO && anchorStartIndex + 1 < positionList.length) {
|
|
7718
|
+
const nextPosition = positionList[anchorStartIndex + 1];
|
|
7719
|
+
const element = elementList[anchorStartIndex];
|
|
7720
|
+
const nextElement = elementList[anchorStartIndex + 1];
|
|
7721
|
+
if (nextPosition.value !== ZERO && !getIsBlockElement(nextElement) && element.listId === nextElement.listId) {
|
|
7722
|
+
draw.getCursor().drawCursor({
|
|
7723
|
+
hitLineStartIndex: anchorStartIndex + 1
|
|
7724
|
+
});
|
|
7725
|
+
}
|
|
7726
|
+
}
|
|
7727
|
+
}
|
|
7680
7728
|
evt.preventDefault();
|
|
7681
7729
|
}
|
|
7682
7730
|
function tab(evt, host) {
|
|
@@ -10973,7 +11021,7 @@ class TextParticle {
|
|
|
10973
11021
|
this.curY = y;
|
|
10974
11022
|
}
|
|
10975
11023
|
_render() {
|
|
10976
|
-
if (!this.text || !~this.curX || !~this.
|
|
11024
|
+
if (!this.text || !~this.curX || !~this.curY)
|
|
10977
11025
|
return;
|
|
10978
11026
|
this.ctx.save();
|
|
10979
11027
|
this.ctx.font = this.curStyle;
|
|
@@ -14142,6 +14190,7 @@ class Control {
|
|
|
14142
14190
|
return this.draw;
|
|
14143
14191
|
}
|
|
14144
14192
|
filterAssistElement(elementList) {
|
|
14193
|
+
const { filterEmptyControl } = this.options.modeRule[EditorMode.PRINT];
|
|
14145
14194
|
return elementList.filter((element, index2) => {
|
|
14146
14195
|
var _a, _b, _c;
|
|
14147
14196
|
if (element.type === ElementType.TABLE) {
|
|
@@ -14193,7 +14242,7 @@ class Control {
|
|
|
14193
14242
|
return isExistValue;
|
|
14194
14243
|
}
|
|
14195
14244
|
}
|
|
14196
|
-
return element.controlComponent !== ControlComponent.PREFIX && element.controlComponent !== ControlComponent.POSTFIX && element.controlComponent !== ControlComponent.PLACEHOLDER;
|
|
14245
|
+
return element.controlComponent !== ControlComponent.PREFIX && element.controlComponent !== ControlComponent.POSTFIX && (!filterEmptyControl || element.controlComponent !== ControlComponent.PLACEHOLDER);
|
|
14197
14246
|
});
|
|
14198
14247
|
}
|
|
14199
14248
|
getIsRangeCanCaptureEvent() {
|
|
@@ -15683,7 +15732,7 @@ function WorkerWrapper$1() {
|
|
|
15683
15732
|
objURL && (window.URL || window.webkitURL).revokeObjectURL(objURL);
|
|
15684
15733
|
}
|
|
15685
15734
|
}
|
|
15686
|
-
const encodedJs = "(()=>{var Te=Object.defineProperty,Ie=Object.defineProperties;var Ae=Object.getOwnPropertyDescriptors;var le=Object.getOwnPropertySymbols;var de=Object.prototype.hasOwnProperty,Re=Object.prototype.propertyIsEnumerable;var ne=(T,I,d)=>I in T?Te(T,I,{enumerable:!0,configurable:!0,writable:!0,value:d}):T[I]=d,g=(T,I)=>{for(var d in I||(I={}))de.call(I,d)&&ne(T,d,I[d]);if(le)for(var d of le(I))Re.call(I,d)&&ne(T,d,I[d]);return T},X=(T,I)=>Ie(T,Ae(I));(function(){"use strict";var T;(function(e){e.HALF="half",e.ONE_THIRD="one-third",e.QUARTER="quarter"})(T||(T={}));var I;(function(e){e.ARABIC="arabic",e.CHINESE="chinese"})(I||(I={}));var d;(function(e){e.INLINE="inline",e.BLOCK="block",e.SURROUND="surround",e.FLOAT_TOP="float-top",e.FLOAT_BOTTOM="float-bottom"})(d||(d={}));var _;(function(e){e.BEFORE="before",e.AFTER="after",e.OUTER_BEFORE="outer-before",e.OUTER_AFTER="outer-after"})(_||(_={}));var M;(function(e){e.ROW="row",e.COLUMN="column"})(M||(M={}));const P="\u200B";T.HALF+"",1/2,T.ONE_THIRD+"",1/3,T.QUARTER+"",1/4;function b(e){if(typeof structuredClone=="function")return structuredClone(e);if(!e||typeof e!="object")return e;let c={};return Array.isArray(e)?c=e.map(E=>b(E)):Object.keys(e).forEach(E=>{c[E]=b(e[E])}),c}function w(e,c){const E={};for(const A in e)c.includes(A)&&(E[A]=e[A]);return E}function re(e,c){return e.length!==c.length?!1:!e.some(E=>!c.includes(E))}var n;(function(e){e.TEXT="text",e.IMAGE="image",e.TABLE="table",e.HYPERLINK="hyperlink",e.SUPERSCRIPT="superscript",e.SUBSCRIPT="subscript",e.SEPARATOR="separator",e.PAGE_BREAK="pageBreak",e.CONTROL="control",e.AREA="area",e.CHECKBOX="checkbox",e.RADIO="radio",e.LATEX="latex",e.TAB="tab",e.DATE="date",e.BLOCK="block",e.TITLE="title",e.LIST="list",e.LABEL="label"})(n||(n={}));const oe=["rowFlex","rowMargin"],ce=["type","font","size","bold","color","italic","highlight","underline","strikeout","rowFlex","rowMargin","dashArray","trList","tableToolDisabled","borderType","borderColor","translateX","width","height","url","colgroup","valueList","control","checkbox","radio","dateFormat","block","level","title","listType","listStyle","listWrap","groupIds","conceptId","imgDisplay","imgFloatPosition","imgToolDisabled","imgPreviewDisabled","imgCrop","imgCaption","textDecoration","extension","externalId","areaId","area","hide","label","labelId","lineWidth"],se=["conceptId","extension","externalId","verticalAlign","backgroundColor","borderTypes","slashTypes","disabled","deletable"],fe=["font","size","bold","highlight","italic","strikeout"];n.TEXT,n.HYPERLINK,n.SUBSCRIPT,n.SUPERSCRIPT,n.CONTROL,n.DATE,n.IMAGE,n.LATEX,n.BLOCK,n.PAGE_BREAK,n.SEPARATOR,n.TABLE,n.TITLE,n.LIST;var N;(function(e){e.UL="ul",e.OL="ol"})(N||(N={}));var O;(function(e){e.DISC="disc",e.CIRCLE="circle",e.SQUARE="square",e.CHECKBOX="checkbox"})(O||(O={}));var H;(function(e){e.DECIMAL="decimal"})(H||(H={}));var v;(function(e){e[e.DISC=O.DISC]="DISC",e[e.CIRCLE=O.CIRCLE]="CIRCLE",e[e.SQUARE=O.SQUARE]="SQUARE",e[e.DECIMAL=H.DECIMAL]="DECIMAL",e[e.CHECKBOX=O.CHECKBOX]="CHECKBOX"})(v||(v={})),O.DISC+"",O.CIRCLE+"",O.SQUARE+"",O.CHECKBOX+"",N.OL+"",N.UL+"",v.DISC+"",v.CIRCLE+"",v.SQUARE+"",v.DECIMAL+"",v.CHECKBOX+"";var u;(function(e){e.FIRST="first",e.SECOND="second",e.THIRD="third",e.FOURTH="fourth",e.FIFTH="fifth",e.SIXTH="sixth"})(u||(u={})),u.FIRST+"",u.SECOND+"",u.THIRD+"",u.FOURTH+"",u.FIFTH+"",u.SIXTH+"",u.FIRST+"",u.SECOND+"",u.THIRD+"",u.FOURTH+"",u.FIFTH+"",u.SIXTH+"",u.FIRST,u.SECOND,u.THIRD,u.FOURTH,u.FIFTH,u.SIXTH;var K;(function(e){e.IFRAME="iframe",e.VIDEO="video"})(K||(K={}));var G;(function(e){e.TEXT="text",e.SELECT="select",e.CHECKBOX="checkbox",e.RADIO="radio",e.DATE="date",e.NUMBER="number"})(G||(G={}));var C;(function(e){e.PREFIX="prefix",e.POSTFIX="postfix",e.PRE_TEXT="preText",e.POST_TEXT="postText",e.PLACEHOLDER="placeholder",e.VALUE="value",e.CHECKBOX="checkbox",e.RADIO="radio"})(C||(C={}));var z;(function(e){e.ROW_START="rowStart",e.VALUE_START="valueStart"})(z||(z={}));var Y;(function(e){e.ACTIVE="active",e.INACTIVE="inactive"})(Y||(Y={}));var V;(function(e){e.NUMBER="number",e.OPERATOR="operator",e.UTILITY="utility",e.EQUAL="equal"})(V||(V={}));var Q;(function(e){e.COMPONENT="component",e.MENU="menu",e.MAIN="main",e.FOOTER="footer",e.CONTEXTMENU="contextmenu",e.POPUP="popup",e.CATALOG="catalog",e.COMMENT="comment"})(Q||(Q={}));var W;(function(e){e.PAGE="page",e.TABLE="table"})(W||(W={}));var q;(function(e){e.EDIT="edit",e.CLEAN="clean",e.READONLY="readonly",e.FORM="form",e.PRINT="print",e.DESIGN="design",e.GRAFFITI="graffiti"})(q||(q={}));var Z;(function(e){e.HEADER="header",e.MAIN="main",e.FOOTER="footer"})(Z||(Z={}));var J;(function(e){e.PAGING="paging",e.CONTINUITY="continuity"})(J||(J={}));var j;(function(e){e.VERTICAL="vertical",e.HORIZONTAL="horizontal"})(j||(j={}));var $;(function(e){e.BREAK_ALL="break-all",e.BREAK_WORD="break-word"})($||($={}));var ee;(function(e){e.SPEED="speed",e.COMPATIBILITY="compatibility"})(ee||(ee={}));var D;(function(e){e.LEFT="left",e.CENTER="center",e.RIGHT="right",e.ALIGNMENT="alignment",e.JUSTIFY="justify"})(D||(D={}));var te;(function(e){e.ALL="all",e.EMPTY="empty",e.EXTERNAL="external",e.INTERNAL="internal",e.DASH="dash"})(te||(te={}));var ie;(function(e){e.TOP="top",e.RIGHT="right",e.BOTTOM="bottom",e.LEFT="left"})(ie||(ie={}));var ae;(function(e){e.FORWARD="forward",e.BACK="back"})(ae||(ae={}));var k;(function(e){e.CONTAIN="contain",e.COVER="cover"})(k||(k={}));var m;(function(e){e.REPEAT="repeat",e.NO_REPEAT="no-repeat",e.REPEAT_X="repeat-x",e.REPEAT_Y="repeat-y"})(m||(m={})),k.COVER,m.NO_REPEAT;var F;(function(e){e.TOP="top",e.MIDDLE="middle",e.BOTTOM="bottom"})(F||(F={})),F.BOTTOM,T.HALF,T.HALF;const Ee={PAGE_NO:"{pageNo}",PAGE_COUNT:"{pageCount}"};D.CENTER,Ee.PAGE_NO,I.ARABIC,F.BOTTOM;var y;(function(e){e.TEXT="text",e.IMAGE="image"})(y||(y={})),y.TEXT,I.ARABIC;var U;(function(e){e.PAGE="page",e.CONTINUITY="continuity"})(U||(U={})),U.CONTINUITY;function ue(e,c){const E=Object.keys(e),A=Object.keys(c);if(E.length!==A.length)return!1;for(let R=0;R<E.length;R++){const a=E[R];if(a!=="value"&&!(a==="groupIds"&&Array.isArray(e[a])&&Array.isArray(c[a])&&re(e[a],c[a]))&&e[a]!==c[a])return!1}return!0}function B(e,c={}){const{extraPickAttrs:E}=c,A=[...ce];E&&A.push(...E);const R={value:e.value===P?`
`:e.value};return A.forEach(a=>{const p=e[a];p!==void 0&&(R[a]=p)}),R}function h(e,c={}){const{extraPickAttrs:E,isClassifyArea:A=!1,isClone:R=!0}=c,a=R?b(e):e,p=[];let i=0;for(;i<a.length;){let t=a[i];if(i===0&&t.value===P&&!t.listId&&(!t.type||t.type===n.TEXT)){i++;continue}if(t.areaId){const l=t.areaId,f=t.area,s=[];for(;i<a.length;){const o=a[i];if(l!==o.areaId){i--;break}delete o.area,delete o.areaId,s.push(o),i++}const r=h(s,c);if(A){const o={type:n.AREA,value:"",areaId:l,area:f};o.valueList=r,t=o}else{p.splice(i,0,...r);continue}}else if(t.titleId&&t.level){const l=t.titleId;if(l){const f=t.level,s={type:n.TITLE,title:t.title,titleId:l,value:"",level:f},r=[];for(;i<a.length;){const o=a[i];if(l!==o.titleId){i--;break}delete o.level,delete o.title,r.push(o),i++}s.valueList=h(r,c),t=s}}else if(t.listId&&t.listType){const l=t.listId;if(l){const f=t.listType,s=t.listStyle,r={type:n.LIST,value:"",listId:l,listType:f,listStyle:s},o=[];for(;i<a.length;){const L=a[i];if(l!==L.listId){i--;break}delete L.listType,delete L.listStyle,o.push(L),i++}r.valueList=h(o,c),t=r}}else if(t.type===n.TABLE){if(t.pagingId){let l=i+1,f=0;for(;l<a.length;){const s=a[l];if(s.pagingId===t.pagingId)t.height+=s.height,t.trList.push(...s.trList),l++,f++;else break}i+=f}if(t.trList)for(let l=0;l<t.trList.length;l++){const f=t.trList[l];delete f.id;for(let s=0;s<f.tdList.length;s++){const r=f.tdList[s],o={colspan:r.colspan,rowspan:r.rowspan,value:h(r.value,X(g({},c),{isClassifyArea:!1}))};se.forEach(L=>{const S=r[L];S!==void 0&&(o[L]=S)}),f.tdList[s]=o}}}else if(t.type===n.HYPERLINK){const l=t.hyperlinkId;if(l){const f={type:n.HYPERLINK,value:"",url:t.url},s=[];for(;i<a.length;){const r=a[i];if(l!==r.hyperlinkId){i--;break}delete r.type,delete r.url,s.push(r),i++}f.valueList=h(s,c),t=f}}else if(t.type===n.DATE){const l=t.dateId;if(l){const f={type:n.DATE,value:"",dateFormat:t.dateFormat},s=[];for(;i<a.length;){const r=a[i];if(l!==r.dateId){i--;break}delete r.type,delete r.dateFormat,s.push(r),i++}f.valueList=h(s,c),t=f}}else if(t.controlId){const l=t.controlId;if(t.controlComponent===C.PREFIX){const f=[];let s=!1,r=i;for(;r<a.length;){const o=a[r];if(l!==o.controlId)break;o.controlComponent===C.VALUE&&(delete o.control,delete o.controlId,f.push(o)),o.controlComponent===C.POSTFIX&&(s=!0),r++}if(s){const o=w(t,fe),L=g(g({},t.control),o),S=X(g({},w(t,oe)),{type:n.CONTROL,value:"",control:L,controlId:l});S.control.value=h(f,c),t=B(S,{extraPickAttrs:E}),i+=r-i-1}}if(t.controlComponent&&(delete t.control,delete t.controlId,t.controlComponent!==C.VALUE&&t.controlComponent!==C.PRE_TEXT&&t.controlComponent!==C.POST_TEXT)){i++;continue}}const x=B(t,{extraPickAttrs:E});if(!t.type||t.type===n.TEXT||t.type===n.SUBSCRIPT||t.type===n.SUPERSCRIPT)for(;i<a.length;){const l=a[i+1];if(i++,l&&ue(x,B(l,{extraPickAttrs:E}))){const f=l.value===P?`
`:l.value;x.value+=f}else break}else i++;p.push(x)}return p}onmessage=e=>{const c=e.data,{options:E,data:A}=c,{extraPickAttrs:R=[]}=E||{},a={header:h(A.header,{extraPickAttrs:R,isClone:!1}),main:h(A.main,{extraPickAttrs:R,isClassifyArea:!0,isClone:!1}),footer:h(A.footer,{extraPickAttrs:R,isClone:!1})};postMessage(a)}})();})();
";
|
|
15735
|
+
const encodedJs = "(()=>{var Ie=Object.defineProperty,Ae=Object.defineProperties;var de=Object.getOwnPropertyDescriptors;var ne=Object.getOwnPropertySymbols;var Re=Object.prototype.hasOwnProperty,Oe=Object.prototype.propertyIsEnumerable;var re=(T,I,d)=>I in T?Ie(T,I,{enumerable:!0,configurable:!0,writable:!0,value:d}):T[I]=d,g=(T,I)=>{for(var d in I||(I={}))Re.call(I,d)&&re(T,d,I[d]);if(ne)for(var d of ne(I))Oe.call(I,d)&&re(T,d,I[d]);return T},X=(T,I)=>Ae(T,de(I));(function(){"use strict";var T;(function(e){e.HALF="half",e.ONE_THIRD="one-third",e.QUARTER="quarter"})(T||(T={}));var I;(function(e){e.ARABIC="arabic",e.CHINESE="chinese"})(I||(I={}));var d;(function(e){e.INLINE="inline",e.BLOCK="block",e.SURROUND="surround",e.FLOAT_TOP="float-top",e.FLOAT_BOTTOM="float-bottom"})(d||(d={}));var _;(function(e){e.BEFORE="before",e.AFTER="after",e.OUTER_BEFORE="outer-before",e.OUTER_AFTER="outer-after"})(_||(_={}));var w;(function(e){e.ROW="row",e.COLUMN="column"})(w||(w={}));const P="\u200B";T.HALF+"",1/2,T.ONE_THIRD+"",1/3,T.QUARTER+"",1/4;function b(e){if(typeof structuredClone=="function")return structuredClone(e);if(!e||typeof e!="object")return e;let c={};return Array.isArray(e)?c=e.map(E=>b(E)):Object.keys(e).forEach(E=>{c[E]=b(e[E])}),c}function K(e,c){const E={};for(const A in e)c.includes(A)&&(E[A]=e[A]);return E}function oe(e,c){return e.length!==c.length?!1:!e.some(E=>!c.includes(E))}var n;(function(e){e.TEXT="text",e.IMAGE="image",e.TABLE="table",e.HYPERLINK="hyperlink",e.SUPERSCRIPT="superscript",e.SUBSCRIPT="subscript",e.SEPARATOR="separator",e.PAGE_BREAK="pageBreak",e.CONTROL="control",e.AREA="area",e.CHECKBOX="checkbox",e.RADIO="radio",e.LATEX="latex",e.TAB="tab",e.DATE="date",e.BLOCK="block",e.TITLE="title",e.LIST="list",e.LABEL="label"})(n||(n={}));const ce=["rowFlex","rowMargin"],se=["type","font","size","bold","color","italic","highlight","underline","strikeout","rowFlex","rowMargin","dashArray","trList","tableToolDisabled","borderType","borderColor","translateX","width","height","url","colgroup","valueList","control","checkbox","radio","dateFormat","block","level","title","listType","listStyle","listWrap","groupIds","conceptId","imgDisplay","imgFloatPosition","imgToolDisabled","imgPreviewDisabled","imgCrop","imgCaption","textDecoration","extension","externalId","areaId","area","hide","label","labelId","lineWidth"],fe=["conceptId","extension","externalId","verticalAlign","backgroundColor","borderTypes","slashTypes","disabled","deletable"],Ee=["font","size","bold","highlight","italic","strikeout"];n.TEXT,n.HYPERLINK,n.SUBSCRIPT,n.SUPERSCRIPT,n.CONTROL,n.DATE,n.IMAGE,n.LATEX,n.BLOCK,n.PAGE_BREAK,n.SEPARATOR,n.TABLE,n.TITLE,n.LIST;var N;(function(e){e.UL="ul",e.OL="ol"})(N||(N={}));var O;(function(e){e.DISC="disc",e.CIRCLE="circle",e.SQUARE="square",e.CHECKBOX="checkbox"})(O||(O={}));var H;(function(e){e.DECIMAL="decimal"})(H||(H={}));var v;(function(e){e[e.DISC=O.DISC]="DISC",e[e.CIRCLE=O.CIRCLE]="CIRCLE",e[e.SQUARE=O.SQUARE]="SQUARE",e[e.DECIMAL=H.DECIMAL]="DECIMAL",e[e.CHECKBOX=O.CHECKBOX]="CHECKBOX"})(v||(v={})),O.DISC+"",O.CIRCLE+"",O.SQUARE+"",O.CHECKBOX+"",N.OL+"",N.UL+"",v.DISC+"",v.CIRCLE+"",v.SQUARE+"",v.DECIMAL+"",v.CHECKBOX+"";var u;(function(e){e.FIRST="first",e.SECOND="second",e.THIRD="third",e.FOURTH="fourth",e.FIFTH="fifth",e.SIXTH="sixth"})(u||(u={})),u.FIRST+"",u.SECOND+"",u.THIRD+"",u.FOURTH+"",u.FIFTH+"",u.SIXTH+"",u.FIRST+"",u.SECOND+"",u.THIRD+"",u.FOURTH+"",u.FIFTH+"",u.SIXTH+"",u.FIRST,u.SECOND,u.THIRD,u.FOURTH,u.FIFTH,u.SIXTH;var G;(function(e){e.IFRAME="iframe",e.VIDEO="video"})(G||(G={}));var z;(function(e){e.TEXT="text",e.SELECT="select",e.CHECKBOX="checkbox",e.RADIO="radio",e.DATE="date",e.NUMBER="number"})(z||(z={}));var C;(function(e){e.PREFIX="prefix",e.POSTFIX="postfix",e.PRE_TEXT="preText",e.POST_TEXT="postText",e.PLACEHOLDER="placeholder",e.VALUE="value",e.CHECKBOX="checkbox",e.RADIO="radio"})(C||(C={}));var Y;(function(e){e.ROW_START="rowStart",e.VALUE_START="valueStart"})(Y||(Y={}));var V;(function(e){e.ACTIVE="active",e.INACTIVE="inactive"})(V||(V={}));var Q;(function(e){e.NUMBER="number",e.OPERATOR="operator",e.UTILITY="utility",e.EQUAL="equal"})(Q||(Q={}));var W;(function(e){e.COMPONENT="component",e.MENU="menu",e.MAIN="main",e.FOOTER="footer",e.CONTEXTMENU="contextmenu",e.POPUP="popup",e.CATALOG="catalog",e.COMMENT="comment"})(W||(W={}));var q;(function(e){e.PAGE="page",e.TABLE="table"})(q||(q={}));var Z;(function(e){e.EDIT="edit",e.CLEAN="clean",e.READONLY="readonly",e.FORM="form",e.PRINT="print",e.DESIGN="design",e.GRAFFITI="graffiti"})(Z||(Z={}));var J;(function(e){e.HEADER="header",e.MAIN="main",e.FOOTER="footer"})(J||(J={}));var j;(function(e){e.PAGING="paging",e.CONTINUITY="continuity"})(j||(j={}));var $;(function(e){e.VERTICAL="vertical",e.HORIZONTAL="horizontal"})($||($={}));var ee;(function(e){e.BREAK_ALL="break-all",e.BREAK_WORD="break-word"})(ee||(ee={}));var te;(function(e){e.SPEED="speed",e.COMPATIBILITY="compatibility"})(te||(te={}));var D;(function(e){e.LEFT="left",e.CENTER="center",e.RIGHT="right",e.ALIGNMENT="alignment",e.JUSTIFY="justify"})(D||(D={}));var ie;(function(e){e.ALL="all",e.EMPTY="empty",e.EXTERNAL="external",e.INTERNAL="internal",e.DASH="dash"})(ie||(ie={}));var ae;(function(e){e.TOP="top",e.RIGHT="right",e.BOTTOM="bottom",e.LEFT="left"})(ae||(ae={}));var le;(function(e){e.FORWARD="forward",e.BACK="back"})(le||(le={}));var k;(function(e){e.CONTAIN="contain",e.COVER="cover"})(k||(k={}));var m;(function(e){e.REPEAT="repeat",e.NO_REPEAT="no-repeat",e.REPEAT_X="repeat-x",e.REPEAT_Y="repeat-y"})(m||(m={})),k.COVER,m.NO_REPEAT;var F;(function(e){e.TOP="top",e.MIDDLE="middle",e.BOTTOM="bottom"})(F||(F={})),F.BOTTOM,T.HALF,T.HALF;const ue={PAGE_NO:"{pageNo}",PAGE_COUNT:"{pageCount}"};D.CENTER,ue.PAGE_NO,I.ARABIC,F.BOTTOM;var y;(function(e){e.TEXT="text",e.IMAGE="image"})(y||(y={}));var U;(function(e){e.BOTTOM="bottom",e.TOP="top"})(U||(U={})),y.TEXT,I.ARABIC,U.BOTTOM;var B;(function(e){e.PAGE="page",e.CONTINUITY="continuity"})(B||(B={})),B.CONTINUITY;function Te(e,c){const E=Object.keys(e),A=Object.keys(c);if(E.length!==A.length)return!1;for(let R=0;R<E.length;R++){const a=E[R];if(a!=="value"&&!(a==="groupIds"&&Array.isArray(e[a])&&Array.isArray(c[a])&&oe(e[a],c[a]))&&e[a]!==c[a])return!1}return!0}function x(e,c={}){const{extraPickAttrs:E}=c,A=[...se];E&&A.push(...E);const R={value:e.value===P?`
`:e.value};return A.forEach(a=>{const p=e[a];p!==void 0&&(R[a]=p)}),R}function h(e,c={}){const{extraPickAttrs:E,isClassifyArea:A=!1,isClone:R=!0}=c,a=R?b(e):e,p=[];let i=0;for(;i<a.length;){let t=a[i];if(i===0&&t.value===P&&!t.listId&&(!t.type||t.type===n.TEXT)){i++;continue}if(t.areaId){const l=t.areaId,f=t.area,s=[];for(;i<a.length;){const o=a[i];if(l!==o.areaId){i--;break}delete o.area,delete o.areaId,s.push(o),i++}const r=h(s,c);if(A){const o={type:n.AREA,value:"",areaId:l,area:f};o.valueList=r,t=o}else{p.splice(i,0,...r);continue}}else if(t.titleId&&t.level){const l=t.titleId;if(l){const f=t.level,s={type:n.TITLE,title:t.title,titleId:l,value:"",level:f},r=[];for(;i<a.length;){const o=a[i];if(l!==o.titleId){i--;break}delete o.level,delete o.title,r.push(o),i++}s.valueList=h(r,c),t=s}}else if(t.listId&&t.listType){const l=t.listId;if(l){const f=t.listType,s=t.listStyle,r={type:n.LIST,value:"",listId:l,listType:f,listStyle:s},o=[];for(;i<a.length;){const L=a[i];if(l!==L.listId){i--;break}delete L.listType,delete L.listStyle,o.push(L),i++}r.valueList=h(o,c),t=r}}else if(t.type===n.TABLE){if(t.pagingId){let l=i+1,f=0;for(;l<a.length;){const s=a[l];if(s.pagingId===t.pagingId)t.height+=s.height,t.trList.push(...s.trList),l++,f++;else break}i+=f}if(t.trList)for(let l=0;l<t.trList.length;l++){const f=t.trList[l];delete f.id;for(let s=0;s<f.tdList.length;s++){const r=f.tdList[s],o={colspan:r.colspan,rowspan:r.rowspan,value:h(r.value,X(g({},c),{isClassifyArea:!1}))};fe.forEach(L=>{const S=r[L];S!==void 0&&(o[L]=S)}),f.tdList[s]=o}}}else if(t.type===n.HYPERLINK){const l=t.hyperlinkId;if(l){const f={type:n.HYPERLINK,value:"",url:t.url},s=[];for(;i<a.length;){const r=a[i];if(l!==r.hyperlinkId){i--;break}delete r.type,delete r.url,s.push(r),i++}f.valueList=h(s,c),t=f}}else if(t.type===n.DATE){const l=t.dateId;if(l){const f={type:n.DATE,value:"",dateFormat:t.dateFormat},s=[];for(;i<a.length;){const r=a[i];if(l!==r.dateId){i--;break}delete r.type,delete r.dateFormat,s.push(r),i++}f.valueList=h(s,c),t=f}}else if(t.controlId){const l=t.controlId;if(t.controlComponent===C.PREFIX){const f=[];let s=!1,r=i;for(;r<a.length;){const o=a[r];if(l!==o.controlId)break;o.controlComponent===C.VALUE&&(delete o.control,delete o.controlId,f.push(o)),o.controlComponent===C.POSTFIX&&(s=!0),r++}if(s){const o=K(t,Ee),L=g(g({},t.control),o),S=X(g({},K(t,ce)),{type:n.CONTROL,value:"",control:L,controlId:l});S.control.value=h(f,c),t=x(S,{extraPickAttrs:E}),i+=r-i-1}}if(t.controlComponent&&(delete t.control,delete t.controlId,t.controlComponent!==C.VALUE&&t.controlComponent!==C.PRE_TEXT&&t.controlComponent!==C.POST_TEXT)){i++;continue}}const M=x(t,{extraPickAttrs:E});if(!t.type||t.type===n.TEXT||t.type===n.SUBSCRIPT||t.type===n.SUPERSCRIPT)for(;i<a.length;){const l=a[i+1];if(i++,l&&Te(M,x(l,{extraPickAttrs:E}))){const f=l.value===P?`
`:l.value;M.value+=f}else break}else i++;p.push(M)}return p}onmessage=e=>{const c=e.data,{options:E,data:A}=c,{extraPickAttrs:R=[]}=E||{},a={header:h(A.header,{extraPickAttrs:R,isClone:!1}),main:h(A.main,{extraPickAttrs:R,isClassifyArea:!0,isClone:!1}),footer:h(A.footer,{extraPickAttrs:R,isClone:!1})};postMessage(a)}})();})();
";
|
|
15687
15736
|
const blob = typeof window !== "undefined" && window.Blob && new Blob([atob(encodedJs)], { type: "text/javascript;charset=utf-8" });
|
|
15688
15737
|
function WorkerWrapper() {
|
|
15689
15738
|
const objURL = blob && (window.URL || window.webkitURL).createObjectURL(blob);
|
|
@@ -15764,6 +15813,12 @@ class WorkerManager {
|
|
|
15764
15813
|
});
|
|
15765
15814
|
});
|
|
15766
15815
|
}
|
|
15816
|
+
destroy() {
|
|
15817
|
+
this.wordCountWorker.terminate();
|
|
15818
|
+
this.catalogWorker.terminate();
|
|
15819
|
+
this.groupWorker.terminate();
|
|
15820
|
+
this.valueWorker.terminate();
|
|
15821
|
+
}
|
|
15767
15822
|
}
|
|
15768
15823
|
class Previewer {
|
|
15769
15824
|
constructor(draw) {
|
|
@@ -16574,7 +16629,6 @@ class BaseBlock {
|
|
|
16574
16629
|
}
|
|
16575
16630
|
} else if (block.type === BlockType.IFRAME) {
|
|
16576
16631
|
this.setClientRects(pageNo, x, y);
|
|
16577
|
-
this.positionInfo = { pageNo, x, y };
|
|
16578
16632
|
}
|
|
16579
16633
|
}
|
|
16580
16634
|
render() {
|
|
@@ -16597,6 +16651,7 @@ class BaseBlock {
|
|
|
16597
16651
|
this.blockItem.style.height = `${metrics.height}px`;
|
|
16598
16652
|
this.blockItem.style.left = `${x}px`;
|
|
16599
16653
|
this.blockItem.style.top = `${preY + y}px`;
|
|
16654
|
+
this.positionInfo = { pageNo, x, y };
|
|
16600
16655
|
}
|
|
16601
16656
|
setStatus() {
|
|
16602
16657
|
if (this.block instanceof IFrameBlock) {
|
|
@@ -16678,6 +16733,27 @@ class BlockParticle {
|
|
|
16678
16733
|
}
|
|
16679
16734
|
});
|
|
16680
16735
|
}
|
|
16736
|
+
async drawIframeToPage(pageList, snapDomFunction) {
|
|
16737
|
+
const tasks = [];
|
|
16738
|
+
this.blockMap.forEach((cacheBlock) => {
|
|
16739
|
+
var _a, _b, _c;
|
|
16740
|
+
if (((_a = cacheBlock.getBlockElement().block) == null ? void 0 : _a.type) !== BlockType.IFRAME)
|
|
16741
|
+
return;
|
|
16742
|
+
const positionInfo = cacheBlock.getPositionInfo();
|
|
16743
|
+
if (!positionInfo)
|
|
16744
|
+
return;
|
|
16745
|
+
const iframe = (_b = cacheBlock.getIFrameBlock()) == null ? void 0 : _b.getIframe();
|
|
16746
|
+
if (!iframe)
|
|
16747
|
+
return;
|
|
16748
|
+
const { pageNo, x, y } = positionInfo;
|
|
16749
|
+
const ctx = (_c = pageList[pageNo]) == null ? void 0 : _c.getContext("2d");
|
|
16750
|
+
if (!ctx)
|
|
16751
|
+
return;
|
|
16752
|
+
const { width, height } = cacheBlock.getBlockElement().metrics;
|
|
16753
|
+
tasks.push(snapDomFunction(iframe).then((base64) => loadImage(base64)).then((img) => ctx.drawImage(img, x, y, width, height)));
|
|
16754
|
+
});
|
|
16755
|
+
await Promise.allSettled(tasks);
|
|
16756
|
+
}
|
|
16681
16757
|
pickIframeInfo() {
|
|
16682
16758
|
const result = [];
|
|
16683
16759
|
const { scale } = this.options;
|
|
@@ -19874,7 +19950,7 @@ class Draw {
|
|
|
19874
19950
|
return this.getRowList().length;
|
|
19875
19951
|
}
|
|
19876
19952
|
async getDataURL(payload = {}) {
|
|
19877
|
-
const { pixelRatio, mode } = payload;
|
|
19953
|
+
const { pixelRatio, mode, snapDomFunction } = payload;
|
|
19878
19954
|
if (pixelRatio) {
|
|
19879
19955
|
this.setPagePixelRatio(pixelRatio);
|
|
19880
19956
|
}
|
|
@@ -19890,6 +19966,9 @@ class Draw {
|
|
|
19890
19966
|
isSubmitHistory: false
|
|
19891
19967
|
});
|
|
19892
19968
|
await this.imageObserver.allSettled();
|
|
19969
|
+
if (snapDomFunction) {
|
|
19970
|
+
await this.blockParticle.drawIframeToPage(this.pageList, snapDomFunction);
|
|
19971
|
+
}
|
|
19893
19972
|
const dataUrlList = this.pageList.map((c) => c.toDataURL());
|
|
19894
19973
|
if (pixelRatio) {
|
|
19895
19974
|
this.setPagePixelRatio(null);
|
|
@@ -20203,7 +20282,7 @@ class Draw {
|
|
|
20203
20282
|
computeRowList(payload) {
|
|
20204
20283
|
var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s, _t, _u, _v;
|
|
20205
20284
|
const { innerWidth, elementList, isPagingMode = false, isFromTable = false, startX = 0, startY = 0, pageHeight = 0, mainOuterHeight = 0, surroundElementList = [] } = payload;
|
|
20206
|
-
const { defaultSize, scale, imgCaption, table: { tdPadding
|
|
20285
|
+
const { defaultSize, scale, imgCaption, table: { tdPadding }, defaultTabWidth } = this.options;
|
|
20207
20286
|
const defaultBasicRowMarginHeight = this.getDefaultBasicRowMarginHeight();
|
|
20208
20287
|
const canvas = document.createElement("canvas");
|
|
20209
20288
|
const ctx = canvas.getContext("2d");
|
|
@@ -20297,9 +20376,10 @@ class Draw {
|
|
|
20297
20376
|
}
|
|
20298
20377
|
element.pagingIndex = (_g = element.pagingIndex) != null ? _g : 0;
|
|
20299
20378
|
const trList = element.trList;
|
|
20379
|
+
const tdMinHeight = tdPaddingHeight + defaultSize + rowMargin * 2 / scale;
|
|
20300
20380
|
for (let t = 0; t < trList.length; t++) {
|
|
20301
20381
|
const tr = trList[t];
|
|
20302
|
-
tr.height = tr.minHeight ||
|
|
20382
|
+
tr.height = Math.max(tdMinHeight, tr.minHeight || 0);
|
|
20303
20383
|
tr.minHeight = tr.height;
|
|
20304
20384
|
}
|
|
20305
20385
|
this.tableParticle.computeRowColInfo(element);
|
|
@@ -20997,6 +21077,7 @@ class Draw {
|
|
|
20997
21077
|
const { elementList, positionList, rowList, pageNo } = payload;
|
|
20998
21078
|
const { inactiveAlpha, pageMode, header, footer, pageNumber, lineNumber, pageBorder } = this.options;
|
|
20999
21079
|
const isPrintMode = this.mode === EditorMode.PRINT;
|
|
21080
|
+
const isContinuityMode = pageMode === PageMode.CONTINUITY;
|
|
21000
21081
|
const innerWidth = this.getInnerWidth();
|
|
21001
21082
|
const ctx = this.ctxList[pageNo];
|
|
21002
21083
|
ctx.globalAlpha = !this.zone.isMainActive() ? inactiveAlpha : 1;
|
|
@@ -21007,7 +21088,7 @@ class Draw {
|
|
|
21007
21088
|
if (!isPrintMode) {
|
|
21008
21089
|
this.area.render(ctx, pageNo);
|
|
21009
21090
|
}
|
|
21010
|
-
if (
|
|
21091
|
+
if (!isContinuityMode && this.options.watermark.data && this.options.watermark.layer === WatermarkLayer.BOTTOM) {
|
|
21011
21092
|
this.waterMark.render(ctx, pageNo);
|
|
21012
21093
|
}
|
|
21013
21094
|
if (!isPrintMode) {
|
|
@@ -21061,6 +21142,9 @@ class Draw {
|
|
|
21061
21142
|
if (this.isGraffitiMode()) {
|
|
21062
21143
|
this.graffiti.render(ctx, pageNo);
|
|
21063
21144
|
}
|
|
21145
|
+
if (!isContinuityMode && this.options.watermark.data && this.options.watermark.layer === WatermarkLayer.TOP) {
|
|
21146
|
+
this.waterMark.render(ctx, pageNo);
|
|
21147
|
+
}
|
|
21064
21148
|
}
|
|
21065
21149
|
_disconnectLazyRender() {
|
|
21066
21150
|
var _a;
|
|
@@ -21260,10 +21344,13 @@ class Draw {
|
|
|
21260
21344
|
});
|
|
21261
21345
|
}
|
|
21262
21346
|
destroy() {
|
|
21347
|
+
var _a;
|
|
21263
21348
|
this.container.remove();
|
|
21264
21349
|
this.globalEvent.removeEvent();
|
|
21265
21350
|
this.scrollObserver.removeEvent();
|
|
21266
21351
|
this.selectionObserver.removeEvent();
|
|
21352
|
+
this.workerManager.destroy();
|
|
21353
|
+
(_a = this.lazyRenderIntersectionObserver) == null ? void 0 : _a.disconnect();
|
|
21267
21354
|
}
|
|
21268
21355
|
clearSideEffect() {
|
|
21269
21356
|
this.getPreviewer().clearResizer();
|
|
@@ -22719,7 +22806,7 @@ class CommandAdapt {
|
|
|
22719
22806
|
if (isReadonly)
|
|
22720
22807
|
return;
|
|
22721
22808
|
const options = this.draw.getOptions();
|
|
22722
|
-
const { color, size, opacity, font, gap } = defaultWatermarkOption;
|
|
22809
|
+
const { color, size, opacity, font, gap, layer } = defaultWatermarkOption;
|
|
22723
22810
|
options.watermark.data = payload.data;
|
|
22724
22811
|
options.watermark.type = payload.type || WatermarkType.TEXT;
|
|
22725
22812
|
if (payload.width) {
|
|
@@ -22737,6 +22824,7 @@ class CommandAdapt {
|
|
|
22737
22824
|
options.watermark.numberType = payload.numberType;
|
|
22738
22825
|
}
|
|
22739
22826
|
options.watermark.gap = payload.gap || gap;
|
|
22827
|
+
options.watermark.layer = payload.layer || layer;
|
|
22740
22828
|
this.draw.render({
|
|
22741
22829
|
isSetCursor: false,
|
|
22742
22830
|
isSubmitHistory: false,
|
|
@@ -25107,5 +25195,5 @@ class Editor {
|
|
|
25107
25195
|
this.use = plugin.use.bind(plugin);
|
|
25108
25196
|
}
|
|
25109
25197
|
}
|
|
25110
|
-
export { AreaMode, BackgroundRepeat, BackgroundSize, BlockType, Command, ControlComponent, ControlIndentation, ControlState, ControlType, EDITOR_CLIPBOARD, EDITOR_COMPONENT, Editor, EditorComponent, EditorMode, EditorZone, ElementType, FlexDirection, INTERNAL_CONTEXT_MENU_KEY, INTERNAL_SHORTCUT_KEY, ImageDisplay, KeyMap, LETTER_CLASS, LineNumberType, ListStyle, ListType, LocationPosition, MaxHeightRatio, NumberType, PageMode, PaperDirection, RenderMode, RowFlex, TableBorder, TdBorder, TdSlash, TextDecorationStyle, TitleLevel, VerticalAlign, WatermarkType, WordBreak, createDomFromElementList, Editor as default, getElementListByHTML, getTextFromElementList, splitText };
|
|
25198
|
+
export { AreaMode, BackgroundRepeat, BackgroundSize, BlockType, Command, ControlComponent, ControlIndentation, ControlState, ControlType, EDITOR_CLIPBOARD, EDITOR_COMPONENT, Editor, EditorComponent, EditorMode, EditorZone, ElementType, FlexDirection, INTERNAL_CONTEXT_MENU_KEY, INTERNAL_SHORTCUT_KEY, ImageDisplay, KeyMap, LETTER_CLASS, LineNumberType, ListStyle, ListType, LocationPosition, MaxHeightRatio, NumberType, PageMode, PaperDirection, RenderMode, RowFlex, TableBorder, TdBorder, TdSlash, TextDecorationStyle, TitleLevel, VerticalAlign, WatermarkLayer, WatermarkType, WordBreak, createDomFromElementList, Editor as default, getElementListByHTML, getTextFromElementList, splitText };
|
|
25111
25199
|
//# sourceMappingURL=canvas-editor.es.js.map
|