@hufe921/canvas-editor 0.9.120 → 0.9.121
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 +18 -0
- package/dist/canvas-editor.es.js +182 -18
- package/dist/canvas-editor.es.js.map +1 -1
- package/dist/canvas-editor.umd.js +32 -32
- package/dist/canvas-editor.umd.js.map +1 -1
- package/dist/src/editor/core/command/Command.d.ts +1 -0
- package/dist/src/editor/core/command/CommandAdapt.d.ts +1 -0
- package/dist/src/editor/core/draw/Draw.d.ts +5 -1
- package/dist/src/editor/core/draw/graffiti/Graffiti.d.ts +19 -0
- package/dist/src/editor/core/draw/particle/TextParticle.d.ts +1 -0
- package/dist/src/editor/core/draw/particle/date/DatePicker.d.ts +1 -1
- package/dist/src/editor/core/event/eventbus/EventBus.d.ts +1 -0
- package/dist/src/editor/dataset/constant/Graffiti.d.ts +2 -0
- package/dist/src/editor/dataset/constant/Regular.d.ts +1 -0
- package/dist/src/editor/dataset/enum/Editor.d.ts +2 -1
- package/dist/src/editor/interface/Editor.d.ts +3 -0
- package/dist/src/editor/interface/Graffiti.d.ts +14 -0
- package/dist/src/editor/interface/Plugin.d.ts +1 -1
- package/dist/src/editor/interface/contextmenu/ContextMenu.d.ts +1 -1
- package/dist/src/editor/interface/shortcut/Shortcut.d.ts +1 -1
- package/dist/src/editor/utils/element.d.ts +1 -0
- package/dist/src/editor/utils/index.d.ts +1 -1
- package/package.json +2 -2
package/CHANGELOG.md
CHANGED
|
@@ -1,3 +1,21 @@
|
|
|
1
|
+
## [0.9.121](https://github.com/Hufe921/canvas-editor/compare/v0.9.120...v0.9.121) (2025-12-19)
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
### Bug Fixes
|
|
5
|
+
|
|
6
|
+
* clear eventbus when destroying editor ([17e7fcd](https://github.com/Hufe921/canvas-editor/commit/17e7fcda00a71e8a4bad8360f8c473f188ba229c))
|
|
7
|
+
* compute position boundary error ([5835396](https://github.com/Hufe921/canvas-editor/commit/58353968376623fcd82a308d8760a2eb449188bf))
|
|
8
|
+
* graffiti mode boundary error ([9781f2d](https://github.com/Hufe921/canvas-editor/commit/9781f2d038d3537fc26bf3cebff0ae452c45b07a))
|
|
9
|
+
* restrict allowed characters in number control #1319 ([9e31b41](https://github.com/Hufe921/canvas-editor/commit/9e31b41720ad5269813db364db3b1c39e9865185)), closes [#1319](https://github.com/Hufe921/canvas-editor/issues/1319)
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
### Features
|
|
13
|
+
|
|
14
|
+
* add graffiti mode #992 ([5bd66a6](https://github.com/Hufe921/canvas-editor/commit/5bd66a641031d0390f7d37d50b1210aed9defc7a)), closes [#992](https://github.com/Hufe921/canvas-editor/issues/992)
|
|
15
|
+
* optimize zero width element ascent calculation #1324 ([890b87d](https://github.com/Hufe921/canvas-editor/commit/890b87da4b3c4b80c725e15956e417eef5dce712)), closes [#1324](https://github.com/Hufe921/canvas-editor/issues/1324)
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
|
|
1
19
|
## [0.9.120](https://github.com/Hufe921/canvas-editor/compare/v0.9.119...v0.9.120) (2025-11-28)
|
|
2
20
|
|
|
3
21
|
|
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.121";
|
|
27
27
|
var MaxHeightRatio;
|
|
28
28
|
(function(MaxHeightRatio2) {
|
|
29
29
|
MaxHeightRatio2["HALF"] = "half";
|
|
@@ -108,6 +108,7 @@ const UNICODE_SYMBOL_REG = new RegExp(`${EMOJI_REG.source}|${SURROGATE_PAIR_REG.
|
|
|
108
108
|
const PUNCTUATION_REG = /[、,。?!;:……「」“”‘’*()【】〔〕〖〗〘〙〚〛《》———﹝﹞–—\\/·.,!?;:`~<>()[\]{}'"|]/;
|
|
109
109
|
const START_LINE_BREAK_REG = new RegExp(`^[${ZERO}
|
|
110
110
|
]`);
|
|
111
|
+
const NON_NUMBER_STR_REG = /[^0-9\+\-\.eE,]/;
|
|
111
112
|
function debounce(func, delay) {
|
|
112
113
|
let timer;
|
|
113
114
|
return function(...args) {
|
|
@@ -148,7 +149,7 @@ function deepCloneOmitKeys(obj, omitKeys) {
|
|
|
148
149
|
Object.keys(obj).forEach((key) => {
|
|
149
150
|
if (omitKeys.includes(key))
|
|
150
151
|
return;
|
|
151
|
-
|
|
152
|
+
newObj[key] = deepCloneOmitKeys(obj[key], omitKeys);
|
|
152
153
|
});
|
|
153
154
|
}
|
|
154
155
|
return newObj;
|
|
@@ -165,7 +166,7 @@ function deepClone(obj) {
|
|
|
165
166
|
newObj = obj.map((item) => deepClone(item));
|
|
166
167
|
} else {
|
|
167
168
|
Object.keys(obj).forEach((key) => {
|
|
168
|
-
|
|
169
|
+
newObj[key] = deepClone(obj[key]);
|
|
169
170
|
});
|
|
170
171
|
}
|
|
171
172
|
return newObj;
|
|
@@ -4112,6 +4113,7 @@ var EditorMode;
|
|
|
4112
4113
|
EditorMode2["FORM"] = "form";
|
|
4113
4114
|
EditorMode2["PRINT"] = "print";
|
|
4114
4115
|
EditorMode2["DESIGN"] = "design";
|
|
4116
|
+
EditorMode2["GRAFFITI"] = "graffiti";
|
|
4115
4117
|
})(EditorMode || (EditorMode = {}));
|
|
4116
4118
|
var EditorZone;
|
|
4117
4119
|
(function(EditorZone2) {
|
|
@@ -4325,6 +4327,10 @@ const defaultBadgeOption = {
|
|
|
4325
4327
|
top: 0,
|
|
4326
4328
|
left: 5
|
|
4327
4329
|
};
|
|
4330
|
+
const defaultGraffitiOption = {
|
|
4331
|
+
defaultLineColor: "#000000",
|
|
4332
|
+
defaultLineWidth: 2
|
|
4333
|
+
};
|
|
4328
4334
|
function mergeOption(options = {}) {
|
|
4329
4335
|
var _a, _b, _c;
|
|
4330
4336
|
const tableOptions = __spreadValues(__spreadValues({}, defaultTableOption), options.table);
|
|
@@ -4347,6 +4353,7 @@ function mergeOption(options = {}) {
|
|
|
4347
4353
|
const lineNumberOptions = __spreadValues(__spreadValues({}, defaultLineNumberOption), options.lineNumber);
|
|
4348
4354
|
const pageBorderOptions = __spreadValues(__spreadValues({}, defaultPageBorderOption), options.pageBorder);
|
|
4349
4355
|
const badgeOptions = __spreadValues(__spreadValues({}, defaultBadgeOption), options.badge);
|
|
4356
|
+
const graffitiOptions = __spreadValues(__spreadValues({}, defaultGraffitiOption), options.graffiti);
|
|
4350
4357
|
const modeRuleOption = {
|
|
4351
4358
|
print: __spreadValues(__spreadValues({}, defaultModeRuleOption.print), (_a = options.modeRule) == null ? void 0 : _a.print),
|
|
4352
4359
|
readonly: __spreadValues(__spreadValues({}, defaultModeRuleOption.readonly), (_b = options.modeRule) == null ? void 0 : _b.readonly),
|
|
@@ -4418,7 +4425,8 @@ function mergeOption(options = {}) {
|
|
|
4418
4425
|
lineNumber: lineNumberOptions,
|
|
4419
4426
|
pageBorder: pageBorderOptions,
|
|
4420
4427
|
badge: badgeOptions,
|
|
4421
|
-
modeRule: modeRuleOption
|
|
4428
|
+
modeRule: modeRuleOption,
|
|
4429
|
+
graffiti: graffitiOptions
|
|
4422
4430
|
});
|
|
4423
4431
|
}
|
|
4424
4432
|
function unzipElementList(elementList) {
|
|
@@ -5121,6 +5129,9 @@ function convertRowFlexToJustifyContent(rowFlex) {
|
|
|
5121
5129
|
function isTextLikeElement(element) {
|
|
5122
5130
|
return !element.type || TEXTLIKE_ELEMENT_TYPE.includes(element.type);
|
|
5123
5131
|
}
|
|
5132
|
+
function isTextElement(element) {
|
|
5133
|
+
return !element.type || element.type === ElementType.TEXT;
|
|
5134
|
+
}
|
|
5124
5135
|
function getElementListText(elementList) {
|
|
5125
5136
|
return elementList.filter((el) => isTextLikeElement(el)).map((el) => el.value).join("").replace(new RegExp(ZERO, "g"), "");
|
|
5126
5137
|
}
|
|
@@ -8563,7 +8574,7 @@ class CanvasEvent {
|
|
|
8563
8574
|
selection.forEach((s) => {
|
|
8564
8575
|
painterStyleKeys.forEach((pKey) => {
|
|
8565
8576
|
const key = pKey;
|
|
8566
|
-
s
|
|
8577
|
+
Reflect.set(s, key, painterStyle[key]);
|
|
8567
8578
|
});
|
|
8568
8579
|
});
|
|
8569
8580
|
this.draw.render({ isSetCursor: false });
|
|
@@ -8998,7 +9009,6 @@ class Position {
|
|
|
8998
9009
|
return { x, y, index: index2 };
|
|
8999
9010
|
}
|
|
9000
9011
|
computePositionList() {
|
|
9001
|
-
var _a;
|
|
9002
9012
|
this.positionList = [];
|
|
9003
9013
|
const innerWidth = this.draw.getInnerWidth();
|
|
9004
9014
|
const pageRowList = this.draw.getPageRowList();
|
|
@@ -9010,7 +9020,9 @@ class Position {
|
|
|
9010
9020
|
let startRowIndex = 0;
|
|
9011
9021
|
for (let i = 0; i < pageRowList.length; i++) {
|
|
9012
9022
|
const rowList = pageRowList[i];
|
|
9013
|
-
|
|
9023
|
+
if (!(rowList == null ? void 0 : rowList.length))
|
|
9024
|
+
continue;
|
|
9025
|
+
const startIndex = rowList[0].startIndex;
|
|
9014
9026
|
this.computePageRowPosition({
|
|
9015
9027
|
positionList: this.positionList,
|
|
9016
9028
|
rowList,
|
|
@@ -10710,6 +10722,9 @@ class TextParticle {
|
|
|
10710
10722
|
this.cacheMeasureText.set(id, textMetrics);
|
|
10711
10723
|
return textMetrics;
|
|
10712
10724
|
}
|
|
10725
|
+
getBasisWordBoundingBoxAscent(ctx, font) {
|
|
10726
|
+
return this.measureBasisWord(ctx, font).actualBoundingBoxAscent;
|
|
10727
|
+
}
|
|
10713
10728
|
complete() {
|
|
10714
10729
|
this._render();
|
|
10715
10730
|
this.text = "";
|
|
@@ -13641,6 +13656,9 @@ class DateControl {
|
|
|
13641
13656
|
}
|
|
13642
13657
|
class NumberControl extends TextControl {
|
|
13643
13658
|
setValue(data2, context = {}, options = {}) {
|
|
13659
|
+
if (data2.some((el) => !isTextElement(el) || NON_NUMBER_STR_REG.test(el.value))) {
|
|
13660
|
+
return -1;
|
|
13661
|
+
}
|
|
13644
13662
|
const elementList = context.elementList || this.control.getElementList();
|
|
13645
13663
|
const range = context.range || this.control.getRange();
|
|
13646
13664
|
this.control.shrinkBoundary(context);
|
|
@@ -15220,7 +15238,7 @@ function WorkerWrapper$1() {
|
|
|
15220
15238
|
objURL && (window.URL || window.webkitURL).revokeObjectURL(objURL);
|
|
15221
15239
|
}
|
|
15222
15240
|
}
|
|
15223
|
-
const encodedJs = "(()=>{var fe=Object.defineProperty,Te=Object.defineProperties;var Ie=Object.getOwnPropertyDescriptors;var ae=Object.getOwnPropertySymbols;var Ae=Object.prototype.hasOwnProperty,de=Object.prototype.propertyIsEnumerable;var ne=(T,I,d)=>I in T?fe(T,I,{enumerable:!0,configurable:!0,writable:!0,value:d}):T[I]=d,g=(T,I)=>{for(var d in I||(I={}))Ae.call(I,d)&&ne(T,d,I[d]);if(ae)for(var d of ae(I))de.call(I,d)&&ne(T,d,I[d]);return T},X=(T,I)=>Te(T,Ie(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 H(e){if(typeof structuredClone=="function")return structuredClone(e);if(!e||typeof e!="object")return e;let s={};return Array.isArray(e)?s=e.map(E=>H(E)):Object.keys(e).forEach(E=>s[E]=H(e[E])),s}function w(e,s){const E={};for(const A in e)s.includes(A)&&(E[A]=e[A]);return E}function le(e,s){return e.length!==s.length?!1:!e.some(E=>!s.includes(E))}var l;(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"})(l||(l={}));const re=["rowFlex","rowMargin"],oe=["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","textDecoration","extension","externalId","areaId","area","hide"],se=["conceptId","extension","externalId","verticalAlign","backgroundColor","borderTypes","slashTypes","disabled","deletable"],ce=["font","size","bold","highlight","italic","strikeout"];l.TEXT,l.HYPERLINK,l.SUBSCRIPT,l.SUPERSCRIPT,l.CONTROL,l.DATE,l.IMAGE,l.LATEX,l.BLOCK,l.PAGE_BREAK,l.SEPARATOR,l.TABLE,l.TITLE,l.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 b;(function(e){e.DECIMAL="decimal"})(b||(b={}));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=b.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 f;(function(e){e.FIRST="first",e.SECOND="second",e.THIRD="third",e.FOURTH="fourth",e.FIFTH="fifth",e.SIXTH="sixth"})(f||(f={})),f.FIRST+"",f.SECOND+"",f.THIRD+"",f.FOURTH+"",f.FIFTH+"",f.SIXTH+"",f.FIRST+"",f.SECOND+"",f.THIRD+"",f.FOURTH+"",f.FIFTH+"",f.SIXTH+"",f.FIRST,f.SECOND,f.THIRD,f.FOURTH,f.FIFTH,f.SIXTH;var K;(function(e){e.IFRAME="iframe",e.VIDEO="video"})(K||(K={}));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 L;(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"})(L||(L={}));var G;(function(e){e.ROW_START="rowStart",e.VALUE_START="valueStart"})(G||(G={}));var Y;(function(e){e.ACTIVE="active",e.INACTIVE="inactive"})(Y||(Y={}));var V;(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"})(V||(V={}));var Q;(function(e){e.PAGE="page",e.TABLE="table"})(Q||(Q={}));var W;(function(e){e.EDIT="edit",e.CLEAN="clean",e.READONLY="readonly",e.FORM="form",e.PRINT="print",e.DESIGN="design"})(W||(W={}));var q;(function(e){e.HEADER="header",e.MAIN="main",e.FOOTER="footer"})(q||(q={}));var Z;(function(e){e.PAGING="paging",e.CONTINUITY="continuity"})(Z||(Z={}));var J;(function(e){e.VERTICAL="vertical",e.HORIZONTAL="horizontal"})(J||(J={}));var j;(function(e){e.BREAK_ALL="break-all",e.BREAK_WORD="break-word"})(j||(j={}));var $;(function(e){e.SPEED="speed",e.COMPATIBILITY="compatibility"})($||($={}));var D;(function(e){e.LEFT="left",e.CENTER="center",e.RIGHT="right",e.ALIGNMENT="alignment",e.JUSTIFY="justify"})(D||(D={}));var ee;(function(e){e.ALL="all",e.EMPTY="empty",e.EXTERNAL="external",e.INTERNAL="internal",e.DASH="dash"})(ee||(ee={}));var te;(function(e){e.TOP="top",e.RIGHT="right",e.BOTTOM="bottom",e.LEFT="left"})(te||(te={}));var ie;(function(e){e.FORWARD="forward",e.BACK="back"})(ie||(ie={}));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={})),y.TEXT,I.ARABIC;var U;(function(e){e.PAGE="page",e.CONTINUITY="continuity"})(U||(U={})),U.CONTINUITY;function Ee(e,s){const E=Object.keys(e),A=Object.keys(s);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(s[a])&&le(e[a],s[a]))&&e[a]!==s[a])return!1}return!0}function B(e,s={}){const{extraPickAttrs:E}=s,A=[...oe];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,s={}){const{extraPickAttrs:E,isClassifyArea:A=!1,isClone:R=!0}=s,a=R?H(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===l.TEXT)){i++;continue}if(t.areaId){const n=t.areaId,u=t.area,c=[];for(;i<a.length;){const o=a[i];if(n!==o.areaId){i--;break}delete o.area,delete o.areaId,c.push(o),i++}const r=h(c,s);if(A){const o={type:l.AREA,value:"",areaId:n,area:u};o.valueList=r,t=o}else{p.splice(i,0,...r);continue}}else if(t.titleId&&t.level){const n=t.titleId;if(n){const u=t.level,c={type:l.TITLE,title:t.title,titleId:n,value:"",level:u},r=[];for(;i<a.length;){const o=a[i];if(n!==o.titleId){i--;break}delete o.level,delete o.title,r.push(o),i++}c.valueList=h(r,s),t=c}}else if(t.listId&&t.listType){const n=t.listId;if(n){const u=t.listType,c=t.listStyle,r={type:l.LIST,value:"",listId:n,listType:u,listStyle:c},o=[];for(;i<a.length;){const C=a[i];if(n!==C.listId){i--;break}delete C.listType,delete C.listStyle,o.push(C),i++}r.valueList=h(o,s),t=r}}else if(t.type===l.TABLE){if(t.pagingId){let n=i+1,u=0;for(;n<a.length;){const c=a[n];if(c.pagingId===t.pagingId)t.height+=c.height,t.trList.push(...c.trList),n++,u++;else break}i+=u}if(t.trList)for(let n=0;n<t.trList.length;n++){const u=t.trList[n];delete u.id;for(let c=0;c<u.tdList.length;c++){const r=u.tdList[c],o={colspan:r.colspan,rowspan:r.rowspan,value:h(r.value,X(g({},s),{isClassifyArea:!1}))};se.forEach(C=>{const S=r[C];S!==void 0&&(o[C]=S)}),u.tdList[c]=o}}}else if(t.type===l.HYPERLINK){const n=t.hyperlinkId;if(n){const u={type:l.HYPERLINK,value:"",url:t.url},c=[];for(;i<a.length;){const r=a[i];if(n!==r.hyperlinkId){i--;break}delete r.type,delete r.url,c.push(r),i++}u.valueList=h(c,s),t=u}}else if(t.type===l.DATE){const n=t.dateId;if(n){const u={type:l.DATE,value:"",dateFormat:t.dateFormat},c=[];for(;i<a.length;){const r=a[i];if(n!==r.dateId){i--;break}delete r.type,delete r.dateFormat,c.push(r),i++}u.valueList=h(c,s),t=u}}else if(t.controlId){const n=t.controlId;if(t.controlComponent===L.PREFIX){const u=[];let c=!1,r=i;for(;r<a.length;){const o=a[r];if(n!==o.controlId)break;o.controlComponent===L.VALUE&&(delete o.control,delete o.controlId,u.push(o)),o.controlComponent===L.POSTFIX&&(c=!0),r++}if(c){const o=w(t,ce),C=g(g({},t.control),o),S=X(g({},w(t,re)),{type:l.CONTROL,value:"",control:C,controlId:n});S.control.value=h(u,s),t=B(S,{extraPickAttrs:E}),i+=r-i-1}}if(t.controlComponent&&(delete t.control,delete t.controlId,t.controlComponent!==L.VALUE&&t.controlComponent!==L.PRE_TEXT&&t.controlComponent!==L.POST_TEXT)){i++;continue}}const x=B(t,{extraPickAttrs:E});if(!t.type||t.type===l.TEXT||t.type===l.SUBSCRIPT||t.type===l.SUPERSCRIPT)for(;i<a.length;){const n=a[i+1];if(i++,n&&Ee(x,B(n,{extraPickAttrs:E}))){const u=n.value===P?`
`:n.value;x.value+=u}else break}else i++;p.push(x)}return p}onmessage=e=>{const s=e.data,{options:E,data:A}=s,{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)}})();})();
";
|
|
15241
|
+
const encodedJs = "(()=>{var fe=Object.defineProperty,Te=Object.defineProperties;var Ie=Object.getOwnPropertyDescriptors;var ae=Object.getOwnPropertySymbols;var Ae=Object.prototype.hasOwnProperty,de=Object.prototype.propertyIsEnumerable;var ne=(T,I,d)=>I in T?fe(T,I,{enumerable:!0,configurable:!0,writable:!0,value:d}):T[I]=d,g=(T,I)=>{for(var d in I||(I={}))Ae.call(I,d)&&ne(T,d,I[d]);if(ae)for(var d of ae(I))de.call(I,d)&&ne(T,d,I[d]);return T},X=(T,I)=>Te(T,Ie(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 H(e){if(typeof structuredClone=="function")return structuredClone(e);if(!e||typeof e!="object")return e;let s={};return Array.isArray(e)?s=e.map(E=>H(E)):Object.keys(e).forEach(E=>{s[E]=H(e[E])}),s}function w(e,s){const E={};for(const A in e)s.includes(A)&&(E[A]=e[A]);return E}function le(e,s){return e.length!==s.length?!1:!e.some(E=>!s.includes(E))}var l;(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"})(l||(l={}));const re=["rowFlex","rowMargin"],oe=["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","textDecoration","extension","externalId","areaId","area","hide"],se=["conceptId","extension","externalId","verticalAlign","backgroundColor","borderTypes","slashTypes","disabled","deletable"],ce=["font","size","bold","highlight","italic","strikeout"];l.TEXT,l.HYPERLINK,l.SUBSCRIPT,l.SUPERSCRIPT,l.CONTROL,l.DATE,l.IMAGE,l.LATEX,l.BLOCK,l.PAGE_BREAK,l.SEPARATOR,l.TABLE,l.TITLE,l.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 b;(function(e){e.DECIMAL="decimal"})(b||(b={}));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=b.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 f;(function(e){e.FIRST="first",e.SECOND="second",e.THIRD="third",e.FOURTH="fourth",e.FIFTH="fifth",e.SIXTH="sixth"})(f||(f={})),f.FIRST+"",f.SECOND+"",f.THIRD+"",f.FOURTH+"",f.FIFTH+"",f.SIXTH+"",f.FIRST+"",f.SECOND+"",f.THIRD+"",f.FOURTH+"",f.FIFTH+"",f.SIXTH+"",f.FIRST,f.SECOND,f.THIRD,f.FOURTH,f.FIFTH,f.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 L;(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"})(L||(L={}));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.COMPONENT="component",e.MENU="menu",e.MAIN="main",e.FOOTER="footer",e.CONTEXTMENU="contextmenu",e.POPUP="popup",e.CATALOG="catalog",e.COMMENT="comment"})(V||(V={}));var Q;(function(e){e.PAGE="page",e.TABLE="table"})(Q||(Q={}));var W;(function(e){e.EDIT="edit",e.CLEAN="clean",e.READONLY="readonly",e.FORM="form",e.PRINT="print",e.DESIGN="design",e.GRAFFITI="graffiti"})(W||(W={}));var q;(function(e){e.HEADER="header",e.MAIN="main",e.FOOTER="footer"})(q||(q={}));var Z;(function(e){e.PAGING="paging",e.CONTINUITY="continuity"})(Z||(Z={}));var J;(function(e){e.VERTICAL="vertical",e.HORIZONTAL="horizontal"})(J||(J={}));var j;(function(e){e.BREAK_ALL="break-all",e.BREAK_WORD="break-word"})(j||(j={}));var $;(function(e){e.SPEED="speed",e.COMPATIBILITY="compatibility"})($||($={}));var D;(function(e){e.LEFT="left",e.CENTER="center",e.RIGHT="right",e.ALIGNMENT="alignment",e.JUSTIFY="justify"})(D||(D={}));var ee;(function(e){e.ALL="all",e.EMPTY="empty",e.EXTERNAL="external",e.INTERNAL="internal",e.DASH="dash"})(ee||(ee={}));var te;(function(e){e.TOP="top",e.RIGHT="right",e.BOTTOM="bottom",e.LEFT="left"})(te||(te={}));var ie;(function(e){e.FORWARD="forward",e.BACK="back"})(ie||(ie={}));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={})),y.TEXT,I.ARABIC;var U;(function(e){e.PAGE="page",e.CONTINUITY="continuity"})(U||(U={})),U.CONTINUITY;function Ee(e,s){const E=Object.keys(e),A=Object.keys(s);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(s[a])&&le(e[a],s[a]))&&e[a]!==s[a])return!1}return!0}function B(e,s={}){const{extraPickAttrs:E}=s,A=[...oe];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,s={}){const{extraPickAttrs:E,isClassifyArea:A=!1,isClone:R=!0}=s,a=R?H(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===l.TEXT)){i++;continue}if(t.areaId){const n=t.areaId,u=t.area,c=[];for(;i<a.length;){const o=a[i];if(n!==o.areaId){i--;break}delete o.area,delete o.areaId,c.push(o),i++}const r=h(c,s);if(A){const o={type:l.AREA,value:"",areaId:n,area:u};o.valueList=r,t=o}else{p.splice(i,0,...r);continue}}else if(t.titleId&&t.level){const n=t.titleId;if(n){const u=t.level,c={type:l.TITLE,title:t.title,titleId:n,value:"",level:u},r=[];for(;i<a.length;){const o=a[i];if(n!==o.titleId){i--;break}delete o.level,delete o.title,r.push(o),i++}c.valueList=h(r,s),t=c}}else if(t.listId&&t.listType){const n=t.listId;if(n){const u=t.listType,c=t.listStyle,r={type:l.LIST,value:"",listId:n,listType:u,listStyle:c},o=[];for(;i<a.length;){const C=a[i];if(n!==C.listId){i--;break}delete C.listType,delete C.listStyle,o.push(C),i++}r.valueList=h(o,s),t=r}}else if(t.type===l.TABLE){if(t.pagingId){let n=i+1,u=0;for(;n<a.length;){const c=a[n];if(c.pagingId===t.pagingId)t.height+=c.height,t.trList.push(...c.trList),n++,u++;else break}i+=u}if(t.trList)for(let n=0;n<t.trList.length;n++){const u=t.trList[n];delete u.id;for(let c=0;c<u.tdList.length;c++){const r=u.tdList[c],o={colspan:r.colspan,rowspan:r.rowspan,value:h(r.value,X(g({},s),{isClassifyArea:!1}))};se.forEach(C=>{const S=r[C];S!==void 0&&(o[C]=S)}),u.tdList[c]=o}}}else if(t.type===l.HYPERLINK){const n=t.hyperlinkId;if(n){const u={type:l.HYPERLINK,value:"",url:t.url},c=[];for(;i<a.length;){const r=a[i];if(n!==r.hyperlinkId){i--;break}delete r.type,delete r.url,c.push(r),i++}u.valueList=h(c,s),t=u}}else if(t.type===l.DATE){const n=t.dateId;if(n){const u={type:l.DATE,value:"",dateFormat:t.dateFormat},c=[];for(;i<a.length;){const r=a[i];if(n!==r.dateId){i--;break}delete r.type,delete r.dateFormat,c.push(r),i++}u.valueList=h(c,s),t=u}}else if(t.controlId){const n=t.controlId;if(t.controlComponent===L.PREFIX){const u=[];let c=!1,r=i;for(;r<a.length;){const o=a[r];if(n!==o.controlId)break;o.controlComponent===L.VALUE&&(delete o.control,delete o.controlId,u.push(o)),o.controlComponent===L.POSTFIX&&(c=!0),r++}if(c){const o=w(t,ce),C=g(g({},t.control),o),S=X(g({},w(t,re)),{type:l.CONTROL,value:"",control:C,controlId:n});S.control.value=h(u,s),t=B(S,{extraPickAttrs:E}),i+=r-i-1}}if(t.controlComponent&&(delete t.control,delete t.controlId,t.controlComponent!==L.VALUE&&t.controlComponent!==L.PRE_TEXT&&t.controlComponent!==L.POST_TEXT)){i++;continue}}const x=B(t,{extraPickAttrs:E});if(!t.type||t.type===l.TEXT||t.type===l.SUBSCRIPT||t.type===l.SUPERSCRIPT)for(;i<a.length;){const n=a[i+1];if(i++,n&&Ee(x,B(n,{extraPickAttrs:E}))){const u=n.value===P?`
`:n.value;x.value+=u}else break}else i++;p.push(x)}return p}onmessage=e=>{const s=e.data,{options:E,data:A}=s,{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)}})();})();
";
|
|
15224
15242
|
const blob = typeof window !== "undefined" && window.Blob && new Blob([atob(encodedJs)], { type: "text/javascript;charset=utf-8" });
|
|
15225
15243
|
function WorkerWrapper() {
|
|
15226
15244
|
const objURL = blob && (window.URL || window.webkitURL).createObjectURL(blob);
|
|
@@ -18522,6 +18540,111 @@ class Badge {
|
|
|
18522
18540
|
}
|
|
18523
18541
|
}
|
|
18524
18542
|
}
|
|
18543
|
+
class Graffiti {
|
|
18544
|
+
constructor(draw, data2) {
|
|
18545
|
+
__publicField(this, "draw");
|
|
18546
|
+
__publicField(this, "options");
|
|
18547
|
+
__publicField(this, "data");
|
|
18548
|
+
__publicField(this, "pageContainer");
|
|
18549
|
+
__publicField(this, "isDrawing", false);
|
|
18550
|
+
__publicField(this, "startStroke", null);
|
|
18551
|
+
this.draw = draw;
|
|
18552
|
+
this.options = draw.getOptions();
|
|
18553
|
+
this.data = data2 || [];
|
|
18554
|
+
this.pageContainer = draw.getPageContainer();
|
|
18555
|
+
this.register();
|
|
18556
|
+
}
|
|
18557
|
+
register() {
|
|
18558
|
+
this.pageContainer.addEventListener("mousedown", this.start.bind(this));
|
|
18559
|
+
this.pageContainer.addEventListener("mouseup", this.stop.bind(this));
|
|
18560
|
+
this.pageContainer.addEventListener("mouseleave", this.stop.bind(this));
|
|
18561
|
+
this.pageContainer.addEventListener("mousemove", this.drawing.bind(this));
|
|
18562
|
+
}
|
|
18563
|
+
start(evt) {
|
|
18564
|
+
if (!this.draw.isGraffitiMode())
|
|
18565
|
+
return;
|
|
18566
|
+
this.isDrawing = true;
|
|
18567
|
+
this.startStroke = {
|
|
18568
|
+
isBegin: true,
|
|
18569
|
+
lineWidth: this.options.graffiti.defaultLineWidth,
|
|
18570
|
+
lineColor: this.options.graffiti.defaultLineColor,
|
|
18571
|
+
linePoints: [evt.offsetX, evt.offsetY]
|
|
18572
|
+
};
|
|
18573
|
+
}
|
|
18574
|
+
stop() {
|
|
18575
|
+
this.isDrawing = false;
|
|
18576
|
+
}
|
|
18577
|
+
drawing(evt) {
|
|
18578
|
+
var _a;
|
|
18579
|
+
if (!this.isDrawing || !this.draw.isGraffitiMode())
|
|
18580
|
+
return;
|
|
18581
|
+
const { offsetX, offsetY } = evt;
|
|
18582
|
+
const DISTANCE = 2;
|
|
18583
|
+
if (this.startStroke && Math.abs(this.startStroke.linePoints[0] - offsetX) < DISTANCE && Math.abs(this.startStroke.linePoints[1] - offsetY) < DISTANCE) {
|
|
18584
|
+
return;
|
|
18585
|
+
}
|
|
18586
|
+
const pageNo = this.draw.getPageNo();
|
|
18587
|
+
let currentValue = this.data.find((item) => item.pageNo === pageNo);
|
|
18588
|
+
if (this.startStroke) {
|
|
18589
|
+
if (!currentValue) {
|
|
18590
|
+
currentValue = {
|
|
18591
|
+
pageNo,
|
|
18592
|
+
strokes: []
|
|
18593
|
+
};
|
|
18594
|
+
this.data.push(currentValue);
|
|
18595
|
+
}
|
|
18596
|
+
currentValue.strokes.push(this.startStroke);
|
|
18597
|
+
this.startStroke = null;
|
|
18598
|
+
}
|
|
18599
|
+
if (!((_a = currentValue == null ? void 0 : currentValue.strokes) == null ? void 0 : _a.length))
|
|
18600
|
+
return;
|
|
18601
|
+
currentValue.strokes.push({
|
|
18602
|
+
linePoints: [offsetX, offsetY]
|
|
18603
|
+
});
|
|
18604
|
+
this.draw.render({
|
|
18605
|
+
isCompute: false,
|
|
18606
|
+
isSetCursor: false,
|
|
18607
|
+
isSubmitHistory: false
|
|
18608
|
+
});
|
|
18609
|
+
}
|
|
18610
|
+
getValue() {
|
|
18611
|
+
return this.data;
|
|
18612
|
+
}
|
|
18613
|
+
compute() {
|
|
18614
|
+
const pageSize = this.draw.getPageRowList().length;
|
|
18615
|
+
for (let d = this.data.length - 1; d >= 0; d--) {
|
|
18616
|
+
const pageNo = this.data[d].pageNo;
|
|
18617
|
+
if (pageNo > pageSize - 1) {
|
|
18618
|
+
this.data.splice(d, 1);
|
|
18619
|
+
}
|
|
18620
|
+
}
|
|
18621
|
+
}
|
|
18622
|
+
clear() {
|
|
18623
|
+
this.data = [];
|
|
18624
|
+
}
|
|
18625
|
+
render(ctx, pageNo) {
|
|
18626
|
+
var _a;
|
|
18627
|
+
const strokes = (_a = this.data.find((item) => item.pageNo === pageNo)) == null ? void 0 : _a.strokes;
|
|
18628
|
+
if (!(strokes == null ? void 0 : strokes.length))
|
|
18629
|
+
return;
|
|
18630
|
+
const { graffiti: { defaultLineColor, defaultLineWidth }, scale } = this.options;
|
|
18631
|
+
ctx.save();
|
|
18632
|
+
for (let s = 0; s < strokes.length; s++) {
|
|
18633
|
+
const stroke = strokes[s];
|
|
18634
|
+
const { isBegin, lineColor, lineWidth, linePoints } = stroke;
|
|
18635
|
+
if (isBegin) {
|
|
18636
|
+
ctx.strokeStyle = lineColor || defaultLineColor;
|
|
18637
|
+
ctx.lineWidth = (lineWidth || defaultLineWidth) * scale;
|
|
18638
|
+
ctx.beginPath();
|
|
18639
|
+
ctx.moveTo(linePoints[0] * scale, linePoints[1] * scale);
|
|
18640
|
+
} else {
|
|
18641
|
+
ctx.lineTo(linePoints[0] * scale, linePoints[1] * scale);
|
|
18642
|
+
}
|
|
18643
|
+
ctx.stroke();
|
|
18644
|
+
}
|
|
18645
|
+
ctx.restore();
|
|
18646
|
+
}
|
|
18647
|
+
}
|
|
18525
18648
|
class Draw {
|
|
18526
18649
|
constructor(rootContainer, options, data2, listener, eventBus, override) {
|
|
18527
18650
|
__publicField(this, "container");
|
|
@@ -18584,6 +18707,7 @@ class Draw {
|
|
|
18584
18707
|
__publicField(this, "scrollObserver");
|
|
18585
18708
|
__publicField(this, "selectionObserver");
|
|
18586
18709
|
__publicField(this, "imageObserver");
|
|
18710
|
+
__publicField(this, "graffiti");
|
|
18587
18711
|
__publicField(this, "LETTER_REG");
|
|
18588
18712
|
__publicField(this, "WORD_LIKE_REG");
|
|
18589
18713
|
__publicField(this, "rowList");
|
|
@@ -18649,6 +18773,7 @@ class Draw {
|
|
|
18649
18773
|
this.lineBreakParticle = new LineBreakParticle(this);
|
|
18650
18774
|
this.control = new Control(this);
|
|
18651
18775
|
this.pageBorder = new PageBorder(this);
|
|
18776
|
+
this.graffiti = new Graffiti(this, data2.graffiti);
|
|
18652
18777
|
this.scrollObserver = new ScrollObserver(this);
|
|
18653
18778
|
this.selectionObserver = new SelectionObserver(this);
|
|
18654
18779
|
this.imageObserver = new ImageObserver();
|
|
@@ -18687,7 +18812,11 @@ class Draw {
|
|
|
18687
18812
|
footer: this.footer.getElementList()
|
|
18688
18813
|
};
|
|
18689
18814
|
const clonePrintModeData = deepClone(this.printModeData);
|
|
18690
|
-
const editorDataKeys = [
|
|
18815
|
+
const editorDataKeys = [
|
|
18816
|
+
"header",
|
|
18817
|
+
"main",
|
|
18818
|
+
"footer"
|
|
18819
|
+
];
|
|
18691
18820
|
editorDataKeys.forEach((key) => {
|
|
18692
18821
|
clonePrintModeData[key] = this.control.filterAssistElement(clonePrintModeData[key]);
|
|
18693
18822
|
});
|
|
@@ -18733,6 +18862,7 @@ class Draw {
|
|
|
18733
18862
|
return false;
|
|
18734
18863
|
case EditorMode.READONLY:
|
|
18735
18864
|
case EditorMode.PRINT:
|
|
18865
|
+
case EditorMode.GRAFFITI:
|
|
18736
18866
|
return true;
|
|
18737
18867
|
case EditorMode.FORM:
|
|
18738
18868
|
return !this.control.getIsRangeWithinControl();
|
|
@@ -18765,6 +18895,9 @@ class Draw {
|
|
|
18765
18895
|
isPrintMode() {
|
|
18766
18896
|
return this.mode === EditorMode.PRINT;
|
|
18767
18897
|
}
|
|
18898
|
+
isGraffitiMode() {
|
|
18899
|
+
return this.mode === EditorMode.GRAFFITI;
|
|
18900
|
+
}
|
|
18768
18901
|
getOriginalWidth() {
|
|
18769
18902
|
const { paperDirection, width, height } = this.options;
|
|
18770
18903
|
return paperDirection === PaperDirection.VERTICAL ? width : height;
|
|
@@ -19171,6 +19304,9 @@ class Draw {
|
|
|
19171
19304
|
getI18n() {
|
|
19172
19305
|
return this.i18n;
|
|
19173
19306
|
}
|
|
19307
|
+
getGraffiti() {
|
|
19308
|
+
return this.graffiti;
|
|
19309
|
+
}
|
|
19174
19310
|
getRowCount() {
|
|
19175
19311
|
return this.getRowList().length;
|
|
19176
19312
|
}
|
|
@@ -19367,7 +19503,8 @@ class Draw {
|
|
|
19367
19503
|
const data2 = {
|
|
19368
19504
|
header: this.getHeaderElementList(),
|
|
19369
19505
|
main: mainElementList,
|
|
19370
|
-
footer: this.getFooterElementList()
|
|
19506
|
+
footer: this.getFooterElementList(),
|
|
19507
|
+
graffiti: this.graffiti.getValue()
|
|
19371
19508
|
};
|
|
19372
19509
|
return data2;
|
|
19373
19510
|
}
|
|
@@ -19384,7 +19521,8 @@ class Draw {
|
|
|
19384
19521
|
}),
|
|
19385
19522
|
footer: zipElementList(originData.footer, {
|
|
19386
19523
|
extraPickAttrs
|
|
19387
|
-
})
|
|
19524
|
+
}),
|
|
19525
|
+
graffiti: originData.graffiti
|
|
19388
19526
|
};
|
|
19389
19527
|
return {
|
|
19390
19528
|
version,
|
|
@@ -19805,7 +19943,7 @@ class Draw {
|
|
|
19805
19943
|
if (element.letterSpacing) {
|
|
19806
19944
|
metrics.width += element.letterSpacing * scale;
|
|
19807
19945
|
}
|
|
19808
|
-
metrics.boundingBoxAscent = (element.value === ZERO ? element.
|
|
19946
|
+
metrics.boundingBoxAscent = (element.value === ZERO ? this.textParticle.getBasisWordBoundingBoxAscent(ctx, element.font) : fontMetrics.actualBoundingBoxAscent) * scale;
|
|
19809
19947
|
metrics.boundingBoxDescent = fontMetrics.actualBoundingBoxDescent * scale;
|
|
19810
19948
|
if (element.type === ElementType.SUPERSCRIPT) {
|
|
19811
19949
|
metrics.boundingBoxAscent += metrics.height / 2;
|
|
@@ -19933,7 +20071,7 @@ class Draw {
|
|
|
19933
20071
|
curRow.width = availableWidth;
|
|
19934
20072
|
}
|
|
19935
20073
|
if (curRow.ascent === rowMargin) {
|
|
19936
|
-
const boundingBoxDescent = this.textParticle.
|
|
20074
|
+
const boundingBoxDescent = this.textParticle.getBasisWordBoundingBoxAscent(ctx, element.font) * scale;
|
|
19937
20075
|
curRow.ascent += boundingBoxDescent;
|
|
19938
20076
|
curRow.height += boundingBoxDescent;
|
|
19939
20077
|
}
|
|
@@ -20039,7 +20177,8 @@ class Draw {
|
|
|
20039
20177
|
this._drawHighlight(ctx, payload);
|
|
20040
20178
|
const { scale, table: { tdPadding }, group: group2, lineBreak } = this.options;
|
|
20041
20179
|
const { rowList, pageNo, elementList, positionList, startIndex, zone: zone2, isDrawLineBreak = !lineBreak.disabled } = payload;
|
|
20042
|
-
const isPrintMode = this.
|
|
20180
|
+
const isPrintMode = this.isPrintMode();
|
|
20181
|
+
const isGraffitiMode = this.isGraffitiMode();
|
|
20043
20182
|
const { isCrossRowCol, tableId } = this.range.getRange();
|
|
20044
20183
|
let index2 = startIndex;
|
|
20045
20184
|
for (let i = 0; i < rowList.length; i++) {
|
|
@@ -20235,7 +20374,7 @@ class Draw {
|
|
|
20235
20374
|
this.underline.render(ctx);
|
|
20236
20375
|
this.strikeout.render(ctx);
|
|
20237
20376
|
this.group.render(ctx);
|
|
20238
|
-
if (!isPrintMode) {
|
|
20377
|
+
if (!isPrintMode && !isGraffitiMode) {
|
|
20239
20378
|
if (rangeRecord.width && rangeRecord.height) {
|
|
20240
20379
|
const { x, y, width, height } = rangeRecord;
|
|
20241
20380
|
this.range.render(ctx, x, y, width, height);
|
|
@@ -20332,6 +20471,9 @@ class Draw {
|
|
|
20332
20471
|
this.pageBorder.render(ctx);
|
|
20333
20472
|
}
|
|
20334
20473
|
this.badge.render(ctx, pageNo);
|
|
20474
|
+
if (this.isGraffitiMode()) {
|
|
20475
|
+
this.graffiti.render(ctx, pageNo);
|
|
20476
|
+
}
|
|
20335
20477
|
}
|
|
20336
20478
|
_disconnectLazyRender() {
|
|
20337
20479
|
var _a;
|
|
@@ -20408,13 +20550,16 @@ class Draw {
|
|
|
20408
20550
|
this.pageRowList = this._computePageList();
|
|
20409
20551
|
this.position.computePositionList();
|
|
20410
20552
|
this.area.compute();
|
|
20411
|
-
if (this.
|
|
20553
|
+
if (!this.isPrintMode()) {
|
|
20412
20554
|
const searchKeyword = this.search.getSearchKeyword();
|
|
20413
20555
|
if (searchKeyword) {
|
|
20414
20556
|
this.search.compute(searchKeyword);
|
|
20415
20557
|
}
|
|
20416
20558
|
this.control.computeHighlightList();
|
|
20417
20559
|
}
|
|
20560
|
+
if (this.isGraffitiMode()) {
|
|
20561
|
+
this.graffiti.compute();
|
|
20562
|
+
}
|
|
20418
20563
|
}
|
|
20419
20564
|
this.imageObserver.clearAll();
|
|
20420
20565
|
this.cursor.recoveryCursor();
|
|
@@ -20625,6 +20770,7 @@ class Command {
|
|
|
20625
20770
|
__publicField(this, "executeSetAreaValue");
|
|
20626
20771
|
__publicField(this, "executeSetAreaProperties");
|
|
20627
20772
|
__publicField(this, "executeLocationArea");
|
|
20773
|
+
__publicField(this, "executeClearGraffiti");
|
|
20628
20774
|
__publicField(this, "executeAppendElementList");
|
|
20629
20775
|
__publicField(this, "executeUpdateElementById");
|
|
20630
20776
|
__publicField(this, "executeDeleteElementById");
|
|
@@ -20762,6 +20908,7 @@ class Command {
|
|
|
20762
20908
|
this.executeSetAreaValue = adapt.setAreaValue.bind(adapt);
|
|
20763
20909
|
this.executeSetAreaProperties = adapt.setAreaProperties.bind(adapt);
|
|
20764
20910
|
this.executeLocationArea = adapt.locationArea.bind(adapt);
|
|
20911
|
+
this.executeClearGraffiti = adapt.clearGraffiti.bind(adapt);
|
|
20765
20912
|
this.executeInsertElementList = adapt.insertElementList.bind(adapt);
|
|
20766
20913
|
this.executeAppendElementList = adapt.appendElementList.bind(adapt);
|
|
20767
20914
|
this.executeUpdateElementById = adapt.updateElementById.bind(adapt);
|
|
@@ -21036,7 +21183,7 @@ class CommandAdapt {
|
|
|
21036
21183
|
painterStyleKeys.forEach((p) => {
|
|
21037
21184
|
const key = p;
|
|
21038
21185
|
if (painterStyle[key] === void 0) {
|
|
21039
|
-
painterStyle
|
|
21186
|
+
Reflect.set(painterStyle, key, s[key]);
|
|
21040
21187
|
}
|
|
21041
21188
|
});
|
|
21042
21189
|
});
|
|
@@ -23042,6 +23189,16 @@ class CommandAdapt {
|
|
|
23042
23189
|
isSubmitHistory: false
|
|
23043
23190
|
});
|
|
23044
23191
|
}
|
|
23192
|
+
clearGraffiti() {
|
|
23193
|
+
this.draw.getGraffiti().clear();
|
|
23194
|
+
if (this.draw.isGraffitiMode()) {
|
|
23195
|
+
this.draw.render({
|
|
23196
|
+
isCompute: false,
|
|
23197
|
+
isSetCursor: false,
|
|
23198
|
+
isSubmitHistory: false
|
|
23199
|
+
});
|
|
23200
|
+
}
|
|
23201
|
+
}
|
|
23045
23202
|
}
|
|
23046
23203
|
class Listener {
|
|
23047
23204
|
constructor() {
|
|
@@ -24142,6 +24299,9 @@ class EventBus {
|
|
|
24142
24299
|
const eventSet = this.eventHub.get(eventName);
|
|
24143
24300
|
return !!eventSet && eventSet.size > 0;
|
|
24144
24301
|
}
|
|
24302
|
+
dangerouslyClearAll() {
|
|
24303
|
+
this.eventHub.clear();
|
|
24304
|
+
}
|
|
24145
24305
|
}
|
|
24146
24306
|
class Override {
|
|
24147
24307
|
constructor() {
|
|
@@ -24165,12 +24325,14 @@ class Editor {
|
|
|
24165
24325
|
let headerElementList = [];
|
|
24166
24326
|
let mainElementList = [];
|
|
24167
24327
|
let footerElementList = [];
|
|
24328
|
+
let graffitiData = [];
|
|
24168
24329
|
if (Array.isArray(data2)) {
|
|
24169
24330
|
mainElementList = data2;
|
|
24170
24331
|
} else {
|
|
24171
24332
|
headerElementList = data2.header || [];
|
|
24172
24333
|
mainElementList = data2.main;
|
|
24173
24334
|
footerElementList = data2.footer || [];
|
|
24335
|
+
graffitiData = data2.graffiti || [];
|
|
24174
24336
|
}
|
|
24175
24337
|
const pageComponentData = [
|
|
24176
24338
|
headerElementList,
|
|
@@ -24190,7 +24352,8 @@ class Editor {
|
|
|
24190
24352
|
const draw = new Draw(container, editorOptions, {
|
|
24191
24353
|
header: headerElementList,
|
|
24192
24354
|
main: mainElementList,
|
|
24193
|
-
footer: footerElementList
|
|
24355
|
+
footer: footerElementList,
|
|
24356
|
+
graffiti: graffitiData
|
|
24194
24357
|
}, this.listener, this.eventBus, this.override);
|
|
24195
24358
|
this.command = new Command(new CommandAdapt(draw));
|
|
24196
24359
|
const contextMenu = new ContextMenu(draw, this.command);
|
|
@@ -24204,6 +24367,7 @@ class Editor {
|
|
|
24204
24367
|
draw.destroy();
|
|
24205
24368
|
shortcut.removeEvent();
|
|
24206
24369
|
contextMenu.removeEvent();
|
|
24370
|
+
this.eventBus.dangerouslyClearAll();
|
|
24207
24371
|
};
|
|
24208
24372
|
const plugin = new Plugin(this);
|
|
24209
24373
|
this.use = plugin.use.bind(plugin);
|