@hufe921/canvas-editor 0.9.106 → 0.9.108

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 CHANGED
@@ -1,3 +1,44 @@
1
+ ## [0.9.108](https://github.com/Hufe921/canvas-editor/compare/v0.9.107...v0.9.108) (2025-04-30)
2
+
3
+
4
+ ### Bug Fixes
5
+
6
+ * delete pickElementAttr method data reference #1107 ([a7a7e47](https://github.com/Hufe921/canvas-editor/commit/a7a7e474b6170d26c2b253c8189720e25e17438b)), closes [#1107](https://github.com/Hufe921/canvas-editor/issues/1107)
7
+ * set non deletable control boundary error #1111 ([34fe3e8](https://github.com/Hufe921/canvas-editor/commit/34fe3e87d03b0abf22511d5054ea966847ef853a)), closes [#1111](https://github.com/Hufe921/canvas-editor/issues/1111)
8
+
9
+
10
+ ### Chores
11
+
12
+ * update README.md ([f6828fb](https://github.com/Hufe921/canvas-editor/commit/f6828fb43a176d3098fe3bac1cd0dde9744d630d))
13
+
14
+
15
+ ### Features
16
+
17
+ * add control disabledBackgroundColor option #1105 ([bb6b5ce](https://github.com/Hufe921/canvas-editor/commit/bb6b5ce711ab784ff4e1f3e2b98629bca2018dbd)), closes [#1105](https://github.com/Hufe921/canvas-editor/issues/1105)
18
+ * locate outside the control #1100 ([949421b](https://github.com/Hufe921/canvas-editor/commit/949421baad9ba5854913af0bc17f1b4df7b88f69)), closes [#1100](https://github.com/Hufe921/canvas-editor/issues/1100)
19
+
20
+
21
+
22
+ ## [0.9.107](https://github.com/Hufe921/canvas-editor/compare/v0.9.106...v0.9.107) (2025-04-18)
23
+
24
+
25
+ ### Bug Fixes
26
+
27
+ * area background position error #1082 ([d708629](https://github.com/Hufe921/canvas-editor/commit/d708629c4883b73c78d722352a6ff5a08642fa9e)), closes [#1082](https://github.com/Hufe921/canvas-editor/issues/1082)
28
+ * delete control element boundary error #1079 ([b8132cd](https://github.com/Hufe921/canvas-editor/commit/b8132cdd82822b2840dee95a88fcc8492737f352)), closes [#1079](https://github.com/Hufe921/canvas-editor/issues/1079)
29
+ * input boundary error when control is disabled #1092 ([353ada2](https://github.com/Hufe921/canvas-editor/commit/353ada21cd70adb61094fef301462063ddc00a01)), closes [#1092](https://github.com/Hufe921/canvas-editor/issues/1092)
30
+ * update area element context #1084 ([a7598d2](https://github.com/Hufe921/canvas-editor/commit/a7598d2a08e87e86ea34e80903f168010362d188)), closes [#1084](https://github.com/Hufe921/canvas-editor/issues/1084)
31
+
32
+
33
+ ### Features
34
+
35
+ * add area deletable option #1014 ([6bb1982](https://github.com/Hufe921/canvas-editor/commit/6bb19824c1f6f31adb99ecac5c8b20d3dfa7b17c)), closes [#1014](https://github.com/Hufe921/canvas-editor/issues/1014)
36
+ * add area placeholder option #1076 ([fd9f780](https://github.com/Hufe921/canvas-editor/commit/fd9f780b537c99d9aaa93054e6bbaee8b363ec45)), closes [#1076](https://github.com/Hufe921/canvas-editor/issues/1076)
37
+ * add conceptId to executeImage api #1080 ([b05eb06](https://github.com/Hufe921/canvas-editor/commit/b05eb065e25162ebf21a32c160db6f3e74365588)), closes [#1080](https://github.com/Hufe921/canvas-editor/issues/1080)
38
+ * remove null values when merging cells #1096 ([f673352](https://github.com/Hufe921/canvas-editor/commit/f673352b095653e85921c02cee7a23a0bd8105b1)), closes [#1096](https://github.com/Hufe921/canvas-editor/issues/1096)
39
+
40
+
41
+
1
42
  ## [0.9.106](https://github.com/Hufe921/canvas-editor/compare/v0.9.105...v0.9.106) (2025-04-04)
2
43
 
3
44
 
package/README.md CHANGED
@@ -26,7 +26,7 @@
26
26
  <a href="https://github.com/Hufe921/canvas-editor/discussions" target="_blank">FAQ</a>
27
27
  </p>
28
28
 
29
- <p align="center">Love the project? Please consider <a href="https://hufe.club/donate.jpg" target="_blank">donating</a> to help it improve!</p>
29
+ <p align="center">Love the project? Please consider <a href="https://hufe.club/donate.jpg" target="_blank">donating(赞助)</a> to help it improve!</p>
30
30
 
31
31
  ## Tips
32
32
 
@@ -23,7 +23,7 @@ var __publicField = (obj, key, value) => {
23
23
  return value;
24
24
  };
25
25
  var index = "";
26
- const version = "0.9.106";
26
+ const version = "0.9.108";
27
27
  var MaxHeightRatio;
28
28
  (function(MaxHeightRatio2) {
29
29
  MaxHeightRatio2["HALF"] = "half";
@@ -47,6 +47,8 @@ var LocationPosition;
47
47
  (function(LocationPosition2) {
48
48
  LocationPosition2["BEFORE"] = "before";
49
49
  LocationPosition2["AFTER"] = "after";
50
+ LocationPosition2["OUTER_BEFORE"] = "outer-before";
51
+ LocationPosition2["OUTER_AFTER"] = "outer-after";
50
52
  })(LocationPosition || (LocationPosition = {}));
51
53
  var FlexDirection;
52
54
  (function(FlexDirection2) {
@@ -3968,7 +3970,8 @@ const defaultControlOption = {
3968
3970
  postfix: "}",
3969
3971
  borderWidth: 1,
3970
3972
  borderColor: "#000000",
3971
- activeBackgroundColor: ""
3973
+ activeBackgroundColor: "",
3974
+ disabledBackgroundColor: ""
3972
3975
  };
3973
3976
  const defaultFooterOption = {
3974
3977
  bottom: 30,
@@ -4248,6 +4251,7 @@ function formatElementList(elementList, options) {
4248
4251
  const value = valueList[v];
4249
4252
  value.areaId = el.areaId || areaId;
4250
4253
  value.area = el.area;
4254
+ value.areaIndex = v;
4251
4255
  if (value.type === ElementType.TABLE) {
4252
4256
  const trList = value.trList;
4253
4257
  for (let r = 0; r < trList.length; r++) {
@@ -4562,7 +4566,7 @@ function isSameElementExceptValue(source, target) {
4562
4566
  }
4563
4567
  function pickElementAttr(payload, option = {}) {
4564
4568
  const { extraPickAttrs } = option;
4565
- const zipAttrs = EDITOR_ELEMENT_ZIP_ATTR;
4569
+ const zipAttrs = [...EDITOR_ELEMENT_ZIP_ATTR];
4566
4570
  if (extraPickAttrs) {
4567
4571
  zipAttrs.push(...extraPickAttrs);
4568
4572
  }
@@ -11951,7 +11955,9 @@ class SelectControl {
11951
11955
  if (!~leftIndex || !~rightIndex)
11952
11956
  return -1;
11953
11957
  const draw = this.control.getDraw();
11954
- draw.spliceElementList(elementList, leftIndex + 1, rightIndex - leftIndex);
11958
+ draw.spliceElementList(elementList, leftIndex + 1, rightIndex - leftIndex, [], {
11959
+ isIgnoreDeletedRule: options.isIgnoreDeletedRule
11960
+ });
11955
11961
  if (isAddPlaceholder) {
11956
11962
  this.control.addPlaceholder(preIndex, context);
11957
11963
  }
@@ -11990,7 +11996,9 @@ class SelectControl {
11990
11996
  const text = this.getText(newCodes);
11991
11997
  if (!text) {
11992
11998
  if (oldCode) {
11993
- const prefixIndex2 = this.clearSelect(context);
11999
+ const prefixIndex2 = this.clearSelect(context, {
12000
+ isIgnoreDeletedRule: options.isIgnoreDeletedRule
12001
+ });
11994
12002
  if (~prefixIndex2) {
11995
12003
  this.control.repaintControl({
11996
12004
  curIndex: prefixIndex2
@@ -12005,7 +12013,8 @@ class SelectControl {
12005
12013
  const valueElement = this.getValue(context)[0];
12006
12014
  const styleElement = valueElement ? pickObject(valueElement, EDITOR_ELEMENT_STYLE_ATTR) : pickObject(elementList[range.startIndex], CONTROL_STYLE_ATTR);
12007
12015
  const prefixIndex = this.clearSelect(context, {
12008
- isAddPlaceholder: false
12016
+ isAddPlaceholder: false,
12017
+ isIgnoreDeletedRule: options.isIgnoreDeletedRule
12009
12018
  });
12010
12019
  if (!~prefixIndex)
12011
12020
  return;
@@ -12169,7 +12178,9 @@ class TextControl {
12169
12178
  const { startIndex, endIndex } = range;
12170
12179
  const draw = this.control.getDraw();
12171
12180
  if (startIndex !== endIndex) {
12172
- draw.spliceElementList(elementList, startIndex + 1, endIndex - startIndex);
12181
+ draw.spliceElementList(elementList, startIndex + 1, endIndex - startIndex, [], {
12182
+ isIgnoreDeletedRule: options.isIgnoreDeletedRule
12183
+ });
12173
12184
  } else {
12174
12185
  this.control.removePlaceholder(startIndex, context);
12175
12186
  }
@@ -12198,7 +12209,9 @@ class TextControl {
12198
12209
  const elementList = context.elementList || this.control.getElementList();
12199
12210
  const range = context.range || this.control.getRange();
12200
12211
  const { startIndex, endIndex } = range;
12201
- this.control.getDraw().spliceElementList(elementList, startIndex + 1, endIndex - startIndex);
12212
+ this.control.getDraw().spliceElementList(elementList, startIndex + 1, endIndex - startIndex, [], {
12213
+ isIgnoreDeletedRule: options.isIgnoreDeletedRule
12214
+ });
12202
12215
  const value = this.getValue(context);
12203
12216
  if (!value.length) {
12204
12217
  this.control.addPlaceholder(startIndex, context);
@@ -12846,7 +12859,9 @@ class DateControl {
12846
12859
  return -1;
12847
12860
  const elementList = context.elementList || this.control.getElementList();
12848
12861
  const draw = this.control.getDraw();
12849
- draw.spliceElementList(elementList, leftIndex + 1, rightIndex - leftIndex);
12862
+ draw.spliceElementList(elementList, leftIndex + 1, rightIndex - leftIndex, [], {
12863
+ isIgnoreDeletedRule: options.isIgnoreDeletedRule
12864
+ });
12850
12865
  if (isAddPlaceholder) {
12851
12866
  this.control.addPlaceholder(leftIndex, context);
12852
12867
  }
@@ -12861,7 +12876,8 @@ class DateControl {
12861
12876
  const valueElement = this.getValue(context)[0];
12862
12877
  const styleElement = valueElement ? pickObject(valueElement, EDITOR_ELEMENT_STYLE_ATTR) : pickObject(elementList[range.startIndex], CONTROL_STYLE_ATTR);
12863
12878
  const prefixIndex = this.clearSelect(context, {
12864
- isAddPlaceholder: false
12879
+ isAddPlaceholder: false,
12880
+ isIgnoreDeletedRule: options.isIgnoreDeletedRule
12865
12881
  });
12866
12882
  if (!~prefixIndex)
12867
12883
  return;
@@ -13719,7 +13735,8 @@ class Control {
13719
13735
  elementList
13720
13736
  };
13721
13737
  const controlRule = {
13722
- isIgnoreDisabledRule: true
13738
+ isIgnoreDisabledRule: true,
13739
+ isIgnoreDeletedRule: true
13723
13740
  };
13724
13741
  if (type === ControlType.TEXT) {
13725
13742
  const formatValue = Array.isArray(value) ? value : value ? [{ value }] : [];
@@ -14445,7 +14462,7 @@ function WorkerWrapper$1() {
14445
14462
  objURL && (window.URL || window.webkitURL).revokeObjectURL(objURL);
14446
14463
  }
14447
14464
  }
14448
- const encodedJs = "(()=>{var Et=Object.defineProperty,ft=Object.defineProperties;var Tt=Object.getOwnPropertyDescriptors;var it=Object.getOwnPropertySymbols;var It=Object.prototype.hasOwnProperty,At=Object.prototype.propertyIsEnumerable;var nt=(T,I,d)=>I in T?Et(T,I,{enumerable:!0,configurable:!0,writable:!0,value:d}):T[I]=d,N=(T,I)=>{for(var d in I||(I={}))It.call(I,d)&&nt(T,d,I[d]);if(it)for(var d of it(I))At.call(I,d)&&nt(T,d,I[d]);return T},x=(T,I)=>ft(T,Tt(I));(function(){"use strict";var T;(function(t){t.HALF="half",t.ONE_THIRD="one-third",t.QUARTER="quarter"})(T||(T={}));var I;(function(t){t.ARABIC="arabic",t.CHINESE="chinese"})(I||(I={}));var d;(function(t){t.INLINE="inline",t.BLOCK="block",t.SURROUND="surround",t.FLOAT_TOP="float-top",t.FLOAT_BOTTOM="float-bottom"})(d||(d={}));var _;(function(t){t.BEFORE="before",t.AFTER="after"})(_||(_={}));var X;(function(t){t.ROW="row",t.COLUMN="column"})(X||(X={}));const F="\u200B";T.HALF+"",1/2,T.ONE_THIRD+"",1/3,T.QUARTER+"",1/4;function H(t){if(typeof structuredClone=="function")return structuredClone(t);if(!t||typeof t!="object")return t;let s={};return Array.isArray(t)?s=t.map(E=>H(E)):Object.keys(t).forEach(E=>s[E]=H(t[E])),s}function M(t,s){const E={};for(const A in t)s.includes(A)&&(E[A]=t[A]);return E}function at(t,s){return t.length!==s.length?!1:!t.some(E=>!s.includes(E))}var l;(function(t){t.TEXT="text",t.IMAGE="image",t.TABLE="table",t.HYPERLINK="hyperlink",t.SUPERSCRIPT="superscript",t.SUBSCRIPT="subscript",t.SEPARATOR="separator",t.PAGE_BREAK="pageBreak",t.CONTROL="control",t.AREA="area",t.CHECKBOX="checkbox",t.RADIO="radio",t.LATEX="latex",t.TAB="tab",t.DATE="date",t.BLOCK="block",t.TITLE="title",t.LIST="list"})(l||(l={}));const lt=["rowFlex","rowMargin"],ot=["type","font","size","bold","color","italic","highlight","underline","strikeout","rowFlex","rowMargin","dashArray","trList","tableToolDisabled","borderType","borderColor","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"],rt=["conceptId","extension","externalId","verticalAlign","backgroundColor","borderTypes","slashTypes","disabled","deletable"],st=["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 g;(function(t){t.UL="ul",t.OL="ol"})(g||(g={}));var O;(function(t){t.DISC="disc",t.CIRCLE="circle",t.SQUARE="square",t.CHECKBOX="checkbox"})(O||(O={}));var b;(function(t){t.DECIMAL="decimal"})(b||(b={}));var v;(function(t){t[t.DISC=O.DISC]="DISC",t[t.CIRCLE=O.CIRCLE]="CIRCLE",t[t.SQUARE=O.SQUARE]="SQUARE",t[t.DECIMAL=b.DECIMAL]="DECIMAL",t[t.CHECKBOX=O.CHECKBOX]="CHECKBOX"})(v||(v={})),O.DISC+"",O.CIRCLE+"",O.SQUARE+"",O.CHECKBOX+"",g.OL+"",g.UL+"",v.DISC+"",v.CIRCLE+"",v.SQUARE+"",v.DECIMAL+"",v.CHECKBOX+"";var f;(function(t){t.FIRST="first",t.SECOND="second",t.THIRD="third",t.FOURTH="fourth",t.FIFTH="fifth",t.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(t){t.IFRAME="iframe",t.VIDEO="video"})(K||(K={}));var w;(function(t){t.TEXT="text",t.SELECT="select",t.CHECKBOX="checkbox",t.RADIO="radio",t.DATE="date",t.NUMBER="number"})(w||(w={}));var C;(function(t){t.PREFIX="prefix",t.POSTFIX="postfix",t.PRE_TEXT="preText",t.POST_TEXT="postText",t.PLACEHOLDER="placeholder",t.VALUE="value",t.CHECKBOX="checkbox",t.RADIO="radio"})(C||(C={}));var z;(function(t){t.ROW_START="rowStart",t.VALUE_START="valueStart"})(z||(z={}));var G;(function(t){t.ACTIVE="active",t.INACTIVE="inactive"})(G||(G={}));var Y;(function(t){t.COMPONENT="component",t.MENU="menu",t.MAIN="main",t.FOOTER="footer",t.CONTEXTMENU="contextmenu",t.POPUP="popup",t.CATALOG="catalog",t.COMMENT="comment"})(Y||(Y={}));var V;(function(t){t.PAGE="page",t.TABLE="table"})(V||(V={}));var Q;(function(t){t.EDIT="edit",t.CLEAN="clean",t.READONLY="readonly",t.FORM="form",t.PRINT="print",t.DESIGN="design"})(Q||(Q={}));var W;(function(t){t.HEADER="header",t.MAIN="main",t.FOOTER="footer"})(W||(W={}));var q;(function(t){t.PAGING="paging",t.CONTINUITY="continuity"})(q||(q={}));var Z;(function(t){t.VERTICAL="vertical",t.HORIZONTAL="horizontal"})(Z||(Z={}));var J;(function(t){t.BREAK_ALL="break-all",t.BREAK_WORD="break-word"})(J||(J={}));var j;(function(t){t.SPEED="speed",t.COMPATIBILITY="compatibility"})(j||(j={}));var D;(function(t){t.LEFT="left",t.CENTER="center",t.RIGHT="right",t.ALIGNMENT="alignment",t.JUSTIFY="justify"})(D||(D={}));var $;(function(t){t.ALL="all",t.EMPTY="empty",t.EXTERNAL="external",t.INTERNAL="internal",t.DASH="dash"})($||($={}));var tt;(function(t){t.TOP="top",t.RIGHT="right",t.BOTTOM="bottom",t.LEFT="left"})(tt||(tt={}));var et;(function(t){t.FORWARD="forward",t.BACK="back"})(et||(et={}));var k;(function(t){t.CONTAIN="contain",t.COVER="cover"})(k||(k={}));var m;(function(t){t.REPEAT="repeat",t.NO_REPEAT="no-repeat",t.REPEAT_X="repeat-x",t.REPEAT_Y="repeat-y"})(m||(m={})),k.COVER,m.NO_REPEAT;var P;(function(t){t.TOP="top",t.MIDDLE="middle",t.BOTTOM="bottom"})(P||(P={})),P.BOTTOM,T.HALF,T.HALF;const ct={PAGE_NO:"{pageNo}",PAGE_COUNT:"{pageCount}"};D.CENTER,ct.PAGE_NO,I.ARABIC,P.BOTTOM,I.ARABIC;var y;(function(t){t.PAGE="page",t.CONTINUITY="continuity"})(y||(y={})),y.CONTINUITY;function ut(t,s){const E=Object.keys(t),A=Object.keys(s);if(E.length!==A.length)return!1;for(let R=0;R<E.length;R++){const n=E[R];if(n!=="value"&&!(n==="groupIds"&&Array.isArray(t[n])&&Array.isArray(s[n])&&at(t[n],s[n]))&&t[n]!==s[n])return!1}return!0}function B(t,s={}){const{extraPickAttrs:E}=s,A=ot;E&&A.push(...E);const R={value:t.value===F?`
`:t.value};return A.forEach(n=>{const p=t[n];p!==void 0&&(R[n]=p)}),R}function h(t,s={}){const{extraPickAttrs:E,isClassifyArea:A=!1,isClone:R=!0}=s,n=R?H(t):t,p=[];let i=0;for(;i<n.length;){let e=n[i];if(i===0&&e.value===F&&!e.listId&&(!e.type||e.type===l.TEXT)){i++;continue}if(e.areaId&&e.area){const a=e.areaId,u=e.area,c=[];for(;i<n.length;){const r=n[i];if(a!==r.areaId){i--;break}delete r.area,delete r.areaId,c.push(r),i++}const o=h(c,s);if(A){const r={type:l.AREA,value:"",areaId:a,area:u};r.valueList=o,e=r}else{p.splice(i,0,...o);continue}}else if(e.titleId&&e.level){const a=e.titleId;if(a){const u=e.level,c={type:l.TITLE,title:e.title,titleId:a,value:"",level:u},o=[];for(;i<n.length;){const r=n[i];if(a!==r.titleId){i--;break}delete r.level,delete r.title,o.push(r),i++}c.valueList=h(o,s),e=c}}else if(e.listId&&e.listType){const a=e.listId;if(a){const u=e.listType,c=e.listStyle,o={type:l.LIST,value:"",listId:a,listType:u,listStyle:c},r=[];for(;i<n.length;){const L=n[i];if(a!==L.listId){i--;break}delete L.listType,delete L.listStyle,r.push(L),i++}o.valueList=h(r,s),e=o}}else if(e.type===l.TABLE){if(e.pagingId){let a=i+1,u=0;for(;a<n.length;){const c=n[a];if(c.pagingId===e.pagingId)e.height+=c.height,e.trList.push(...c.trList),a++,u++;else break}i+=u}if(e.trList)for(let a=0;a<e.trList.length;a++){const u=e.trList[a];delete u.id;for(let c=0;c<u.tdList.length;c++){const o=u.tdList[c],r={colspan:o.colspan,rowspan:o.rowspan,value:h(o.value,x(N({},s),{isClassifyArea:!1}))};rt.forEach(L=>{const S=o[L];S!==void 0&&(r[L]=S)}),u.tdList[c]=r}}}else if(e.type===l.HYPERLINK){const a=e.hyperlinkId;if(a){const u={type:l.HYPERLINK,value:"",url:e.url},c=[];for(;i<n.length;){const o=n[i];if(a!==o.hyperlinkId){i--;break}delete o.type,delete o.url,c.push(o),i++}u.valueList=h(c,s),e=u}}else if(e.type===l.DATE){const a=e.dateId;if(a){const u={type:l.DATE,value:"",dateFormat:e.dateFormat},c=[];for(;i<n.length;){const o=n[i];if(a!==o.dateId){i--;break}delete o.type,delete o.dateFormat,c.push(o),i++}u.valueList=h(c,s),e=u}}else if(e.controlId){const a=e.controlId;if(e.controlComponent===C.PREFIX){const u=[];let c=!1,o=i;for(;o<n.length;){const r=n[o];if(a!==r.controlId)break;r.controlComponent===C.VALUE&&(delete r.control,delete r.controlId,u.push(r)),r.controlComponent===C.POSTFIX&&(c=!0),o++}if(c){const r=M(e,st),L=N(N({},e.control),r),S=x(N({},M(e,lt)),{type:l.CONTROL,value:"",control:L,controlId:a});S.control.value=h(u,s),e=B(S,{extraPickAttrs:E}),i+=o-i-1}}if(e.controlComponent&&(delete e.control,delete e.controlId,e.controlComponent!==C.VALUE&&e.controlComponent!==C.PRE_TEXT&&e.controlComponent!==C.POST_TEXT)){i++;continue}}const U=B(e,{extraPickAttrs:E});if(!e.type||e.type===l.TEXT||e.type===l.SUBSCRIPT||e.type===l.SUPERSCRIPT)for(;i<n.length;){const a=n[i+1];if(i++,a&&ut(U,B(a,{extraPickAttrs:E}))){const u=a.value===F?`
`:a.value;U.value+=u}else break}else i++;p.push(U)}return p}onmessage=t=>{const s=t.data,{options:E,data:A}=s,{extraPickAttrs:R=[]}=E||{},n={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(n)}})();})();
";
14465
+ const encodedJs = "(()=>{var Ee=Object.defineProperty,fe=Object.defineProperties;var Te=Object.getOwnPropertyDescriptors;var ie=Object.getOwnPropertySymbols;var Ie=Object.prototype.hasOwnProperty,Ae=Object.prototype.propertyIsEnumerable;var ae=(T,I,d)=>I in T?Ee(T,I,{enumerable:!0,configurable:!0,writable:!0,value:d}):T[I]=d,N=(T,I)=>{for(var d in I||(I={}))Ie.call(I,d)&&ae(T,d,I[d]);if(ie)for(var d of ie(I))Ae.call(I,d)&&ae(T,d,I[d]);return T},_=(T,I)=>fe(T,Te(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 x;(function(e){e.BEFORE="before",e.AFTER="after",e.OUTER_BEFORE="outer-before",e.OUTER_AFTER="outer-after"})(x||(x={}));var X;(function(e){e.ROW="row",e.COLUMN="column"})(X||(X={}));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 M(e,s){const E={};for(const A in e)s.includes(A)&&(E[A]=e[A]);return E}function ne(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 le=["rowFlex","rowMargin"],re=["type","font","size","bold","color","italic","highlight","underline","strikeout","rowFlex","rowMargin","dashArray","trList","tableToolDisabled","borderType","borderColor","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"],oe=["conceptId","extension","externalId","verticalAlign","backgroundColor","borderTypes","slashTypes","disabled","deletable"],se=["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 g;(function(e){e.UL="ul",e.OL="ol"})(g||(g={}));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+"",g.OL+"",g.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 w;(function(e){e.TEXT="text",e.SELECT="select",e.CHECKBOX="checkbox",e.RADIO="radio",e.DATE="date",e.NUMBER="number"})(w||(w={}));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 G;(function(e){e.ACTIVE="active",e.INACTIVE="inactive"})(G||(G={}));var Y;(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"})(Y||(Y={}));var V;(function(e){e.PAGE="page",e.TABLE="table"})(V||(V={}));var Q;(function(e){e.EDIT="edit",e.CLEAN="clean",e.READONLY="readonly",e.FORM="form",e.PRINT="print",e.DESIGN="design"})(Q||(Q={}));var W;(function(e){e.HEADER="header",e.MAIN="main",e.FOOTER="footer"})(W||(W={}));var q;(function(e){e.PAGING="paging",e.CONTINUITY="continuity"})(q||(q={}));var Z;(function(e){e.VERTICAL="vertical",e.HORIZONTAL="horizontal"})(Z||(Z={}));var J;(function(e){e.BREAK_ALL="break-all",e.BREAK_WORD="break-word"})(J||(J={}));var j;(function(e){e.SPEED="speed",e.COMPATIBILITY="compatibility"})(j||(j={}));var D;(function(e){e.LEFT="left",e.CENTER="center",e.RIGHT="right",e.ALIGNMENT="alignment",e.JUSTIFY="justify"})(D||(D={}));var $;(function(e){e.ALL="all",e.EMPTY="empty",e.EXTERNAL="external",e.INTERNAL="internal",e.DASH="dash"})($||($={}));var ee;(function(e){e.TOP="top",e.RIGHT="right",e.BOTTOM="bottom",e.LEFT="left"})(ee||(ee={}));var te;(function(e){e.FORWARD="forward",e.BACK="back"})(te||(te={}));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 ce={PAGE_NO:"{pageNo}",PAGE_COUNT:"{pageCount}"};D.CENTER,ce.PAGE_NO,I.ARABIC,F.BOTTOM,I.ARABIC;var y;(function(e){e.PAGE="page",e.CONTINUITY="continuity"})(y||(y={})),y.CONTINUITY;function ue(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])&&ne(e[a],s[a]))&&e[a]!==s[a])return!1}return!0}function U(e,s={}){const{extraPickAttrs:E}=s,A=[...re];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&&t.area){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,_(N({},s),{isClassifyArea:!1}))};oe.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=M(t,se),C=N(N({},t.control),o),S=_(N({},M(t,le)),{type:l.CONTROL,value:"",control:C,controlId:n});S.control.value=h(u,s),t=U(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 B=U(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&&ue(B,U(n,{extraPickAttrs:E}))){const u=n.value===P?`
`:n.value;B.value+=u}else break}else i++;p.push(B)}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)}})();})();
";
14449
14466
  const blob = typeof window !== "undefined" && window.Blob && new Blob([atob(encodedJs)], { type: "text/javascript;charset=utf-8" });
14450
14467
  function WorkerWrapper() {
14451
14468
  const objURL = blob && (window.URL || window.webkitURL).createObjectURL(blob);
@@ -15928,9 +15945,9 @@ class Placeholder {
15928
15945
  this.rowList = [];
15929
15946
  this.positionList = [];
15930
15947
  }
15931
- _compute() {
15948
+ _compute(options) {
15932
15949
  this._computeRowList();
15933
- this._computePositionList();
15950
+ this._computePositionList(options);
15934
15951
  }
15935
15952
  _computeRowList() {
15936
15953
  const innerWidth = this.draw.getInnerWidth();
@@ -15939,7 +15956,7 @@ class Placeholder {
15939
15956
  elementList: this.elementList
15940
15957
  });
15941
15958
  }
15942
- _computePositionList() {
15959
+ _computePositionList(options) {
15943
15960
  const { lineBreak, scale } = this.options;
15944
15961
  const headerExtraHeight = this.draw.getHeader().getExtraHeight();
15945
15962
  const innerWidth = this.draw.getInnerWidth();
@@ -15948,7 +15965,7 @@ class Placeholder {
15948
15965
  if (!lineBreak.disabled) {
15949
15966
  startX += (LineBreakParticle.WIDTH + LineBreakParticle.GAP) * scale;
15950
15967
  }
15951
- const startY = margins[0] + headerExtraHeight;
15968
+ const startY = (options == null ? void 0 : options.startY) || margins[0] + headerExtraHeight;
15952
15969
  this.position.computePageRowPosition({
15953
15970
  positionList: this.positionList,
15954
15971
  rowList: this.rowList,
@@ -15960,10 +15977,9 @@ class Placeholder {
15960
15977
  innerWidth
15961
15978
  });
15962
15979
  }
15963
- render(ctx) {
15964
- const { placeholder: { data: data2, font, size, color, opacity } } = this.options;
15965
- if (!data2)
15966
- return;
15980
+ render(ctx, options) {
15981
+ const { placeholder = this.options.placeholder } = options || {};
15982
+ const { data: data2, font, size, color, opacity } = placeholder;
15967
15983
  this._recovery();
15968
15984
  this.elementList = [
15969
15985
  {
@@ -15977,7 +15993,7 @@ class Placeholder {
15977
15993
  editorOptions: this.options,
15978
15994
  isForceCompensation: true
15979
15995
  });
15980
- this._compute();
15996
+ this._compute(options);
15981
15997
  const innerWidth = this.draw.getInnerWidth();
15982
15998
  ctx.save();
15983
15999
  ctx.globalAlpha = opacity;
@@ -16753,7 +16769,8 @@ class TableOperate {
16753
16769
  const isAnchorTd = t === 0 && d === 0;
16754
16770
  if (!isAnchorTd) {
16755
16771
  mergeTdIdList.push(td.id);
16756
- for (let d2 = 0; d2 < td.value.length; d2++) {
16772
+ const startTdValueIndex = td.value.length > 1 ? 0 : 1;
16773
+ for (let d2 = startTdValueIndex; d2 < td.value.length; d2++) {
16757
16774
  const tdElement = td.value[d2];
16758
16775
  cloneProperty(TABLE_CONTEXT_ATTR, anchorElement, tdElement);
16759
16776
  anchorTd.value.push(tdElement);
@@ -17203,8 +17220,9 @@ class Area {
17203
17220
  const width = this.draw.getInnerWidth();
17204
17221
  for (const areaInfoItem of this.areaInfoMap) {
17205
17222
  const { area, positionList } = areaInfoItem[1];
17206
- if (!(area == null ? void 0 : area.backgroundColor) && !(area == null ? void 0 : area.borderColor))
17223
+ if (!(area == null ? void 0 : area.backgroundColor) && !(area == null ? void 0 : area.borderColor) && !(area == null ? void 0 : area.placeholder)) {
17207
17224
  continue;
17225
+ }
17208
17226
  const pagePositionList = positionList.filter((p) => p.pageNo === pageNo);
17209
17227
  if (!pagePositionList.length)
17210
17228
  continue;
@@ -17222,6 +17240,14 @@ class Area {
17222
17240
  ctx.strokeStyle = area.borderColor;
17223
17241
  ctx.strokeRect(x, y, width, height);
17224
17242
  }
17243
+ if (area.placeholder && positionList.length <= 1) {
17244
+ const placeholder = new Placeholder(this.draw);
17245
+ placeholder.render(ctx, {
17246
+ placeholder: __spreadValues(__spreadValues({}, defaultPlaceholderOption), area.placeholder),
17247
+ startY: firstPosition.coordinate.leftTop[1]
17248
+ });
17249
+ }
17250
+ ctx.translate(-0.5, -0.5);
17225
17251
  }
17226
17252
  ctx.restore();
17227
17253
  }
@@ -17604,7 +17630,7 @@ class Draw {
17604
17630
  if (startIndex === endIndex) {
17605
17631
  const startElement = elementList[startIndex];
17606
17632
  const nextElement = elementList[startIndex + 1];
17607
- return !!(((_b = startElement == null ? void 0 : startElement.title) == null ? void 0 : _b.disabled) && ((_c = nextElement == null ? void 0 : nextElement.title) == null ? void 0 : _c.disabled) || ((_d = startElement == null ? void 0 : startElement.control) == null ? void 0 : _d.disabled) && ((_e = nextElement == null ? void 0 : nextElement.control) == null ? void 0 : _e.disabled));
17633
+ return !!(((_b = startElement == null ? void 0 : startElement.title) == null ? void 0 : _b.disabled) && ((_c = nextElement == null ? void 0 : nextElement.title) == null ? void 0 : _c.disabled) && startElement.titleId === nextElement.titleId || ((_d = startElement == null ? void 0 : startElement.control) == null ? void 0 : _d.disabled) && ((_e = nextElement == null ? void 0 : nextElement.control) == null ? void 0 : _e.disabled) && startElement.controlId === nextElement.controlId);
17608
17634
  }
17609
17635
  const selectionElementList = elementList.slice(startIndex + 1, endIndex + 1);
17610
17636
  return selectionElementList.some((element) => {
@@ -17615,6 +17641,9 @@ class Draw {
17615
17641
  isDesignMode() {
17616
17642
  return this.mode === EditorMode.DESIGN;
17617
17643
  }
17644
+ isPrintMode() {
17645
+ return this.mode === EditorMode.PRINT;
17646
+ }
17618
17647
  getOriginalWidth() {
17619
17648
  const { paperDirection, width, height } = this.options;
17620
17649
  return paperDirection === PaperDirection.VERTICAL ? width : height;
@@ -17908,9 +17937,9 @@ class Draw {
17908
17937
  curIndex
17909
17938
  });
17910
17939
  }
17911
- spliceElementList(elementList, start, deleteCount, items) {
17912
- var _a, _b, _c, _d, _e;
17913
- const isDesignMode = this.isDesignMode();
17940
+ spliceElementList(elementList, start, deleteCount, items, options) {
17941
+ var _a, _b, _c, _d, _e, _f;
17942
+ const { isIgnoreDeletedRule = false } = options || {};
17914
17943
  if (deleteCount > 0) {
17915
17944
  const endIndex = start + deleteCount;
17916
17945
  const endElement = elementList[endIndex];
@@ -17928,12 +17957,12 @@ class Draw {
17928
17957
  startIndex++;
17929
17958
  }
17930
17959
  }
17931
- if (!this.control.getActiveControl()) {
17960
+ if (!isIgnoreDeletedRule && !this.isDesignMode() && !this.control.getIsRangeWithinControl()) {
17932
17961
  const tdDeletable = (_b = this.getTd()) == null ? void 0 : _b.deletable;
17933
17962
  let deleteIndex = endIndex - 1;
17934
17963
  while (deleteIndex >= start) {
17935
17964
  const deleteElement = elementList[deleteIndex];
17936
- if (isDesignMode || ((_c = deleteElement == null ? void 0 : deleteElement.control) == null ? void 0 : _c.hide) || tdDeletable !== false && ((_d = deleteElement == null ? void 0 : deleteElement.control) == null ? void 0 : _d.deletable) !== false && ((_e = deleteElement == null ? void 0 : deleteElement.title) == null ? void 0 : _e.deletable) !== false) {
17965
+ if (((_c = deleteElement == null ? void 0 : deleteElement.control) == null ? void 0 : _c.hide) || tdDeletable !== false && ((_d = deleteElement == null ? void 0 : deleteElement.control) == null ? void 0 : _d.deletable) !== false && ((_e = deleteElement == null ? void 0 : deleteElement.title) == null ? void 0 : _e.deletable) !== false && (((_f = deleteElement == null ? void 0 : deleteElement.area) == null ? void 0 : _f.deletable) !== false || (deleteElement == null ? void 0 : deleteElement.areaIndex) !== 0)) {
17937
17966
  elementList.splice(deleteIndex, 1);
17938
17967
  }
17939
17968
  deleteIndex--;
@@ -18846,22 +18875,25 @@ class Draw {
18846
18875
  return pageRowList;
18847
18876
  }
18848
18877
  _drawHighlight(ctx, payload) {
18849
- var _a;
18850
- const { control: { activeBackgroundColor } } = this.options;
18878
+ var _a, _b;
18879
+ const { control: { activeBackgroundColor, disabledBackgroundColor } } = this.options;
18851
18880
  const { rowList, positionList } = payload;
18881
+ const isPrintMode = this.isPrintMode();
18852
18882
  const activeControlElement = (_a = this.control.getActiveControl()) == null ? void 0 : _a.getElement();
18853
18883
  for (let i = 0; i < rowList.length; i++) {
18854
18884
  const curRow = rowList[i];
18855
18885
  for (let j = 0; j < curRow.elementList.length; j++) {
18856
18886
  const element = curRow.elementList[j];
18857
18887
  const preElement = curRow.elementList[j - 1];
18858
- if (element.highlight || activeBackgroundColor && activeControlElement && element.controlId === activeControlElement.controlId && !this.control.getIsRangeInPostfix()) {
18888
+ const isActiveControlHighlight = !isPrintMode && activeBackgroundColor && activeControlElement && element.controlId === activeControlElement.controlId && !this.control.getIsRangeInPostfix();
18889
+ const isDisabledControlHighlight = !isPrintMode && disabledBackgroundColor && ((_b = element.control) == null ? void 0 : _b.disabled);
18890
+ if (element.highlight || isActiveControlHighlight || isDisabledControlHighlight) {
18859
18891
  if (preElement && preElement.highlight && preElement.highlight !== element.highlight) {
18860
18892
  this.highlight.render(ctx);
18861
18893
  }
18862
18894
  const { coordinate: { leftTop: [x, y] } } = positionList[curRow.startIndex + j];
18863
18895
  const offsetX = element.left || 0;
18864
- this.highlight.recordFillInfo(ctx, x - offsetX, y, element.metrics.width + offsetX, curRow.height, element.highlight || activeBackgroundColor);
18896
+ this.highlight.recordFillInfo(ctx, x - offsetX, y, element.metrics.width + offsetX, curRow.height, element.highlight || (isActiveControlHighlight ? activeBackgroundColor : "") || (isDisabledControlHighlight ? disabledBackgroundColor : ""));
18865
18897
  } else if (preElement == null ? void 0 : preElement.highlight) {
18866
18898
  this.highlight.render(ctx);
18867
18899
  }
@@ -20756,13 +20788,14 @@ class CommandAdapt {
20756
20788
  const { startIndex, endIndex } = this.range.getRange();
20757
20789
  if (!~startIndex && !~endIndex)
20758
20790
  return null;
20759
- const { id, value, width, height, imgDisplay } = payload;
20791
+ const { id, conceptId, value, width, height, imgDisplay } = payload;
20760
20792
  const imageId = id || getUUID();
20761
20793
  this.insertElementList([
20762
20794
  {
20763
20795
  value,
20764
20796
  width,
20765
20797
  height,
20798
+ conceptId,
20766
20799
  id: imageId,
20767
20800
  type: ElementType.IMAGE,
20768
20801
  imgDisplay
@@ -21177,9 +21210,13 @@ class CommandAdapt {
21177
21210
  return;
21178
21211
  for (let i = 0; i < updateElementInfoList.length; i++) {
21179
21212
  const { elementList, index: index2 } = updateElementInfoList[i];
21213
+ const oldElement = elementList[index2];
21180
21214
  const newElement = zipElementList([
21181
- __spreadValues(__spreadValues({}, elementList[index2]), payload.properties)
21182
- ]);
21215
+ __spreadValues(__spreadValues({}, oldElement), payload.properties)
21216
+ ], {
21217
+ extraPickAttrs: ["id"]
21218
+ });
21219
+ cloneProperty(AREA_CONTEXT_ATTR, oldElement, newElement[0]);
21183
21220
  formatElementList(newElement, {
21184
21221
  isHandleFirstElement: false,
21185
21222
  editorOptions: this.options
@@ -21477,9 +21514,8 @@ class CommandAdapt {
21477
21514
  return this.draw.getControl().getList();
21478
21515
  }
21479
21516
  locationControl(controlId, options) {
21480
- const isLocationAfter = (options == null ? void 0 : options.position) === LocationPosition.AFTER;
21481
21517
  function location(elementList, zone2) {
21482
- var _a, _b;
21518
+ var _a, _b, _c;
21483
21519
  let i = 0;
21484
21520
  while (i < elementList.length) {
21485
21521
  const element = elementList[i];
@@ -21510,13 +21546,19 @@ class CommandAdapt {
21510
21546
  if ((element == null ? void 0 : element.controlId) !== controlId)
21511
21547
  continue;
21512
21548
  let curIndex = i - 1;
21513
- if (isLocationAfter) {
21549
+ if ((options == null ? void 0 : options.position) === LocationPosition.OUTER_AFTER) {
21550
+ if (!(element.controlComponent === ControlComponent.POSTFIX && ((_a = elementList[i + 1]) == null ? void 0 : _a.controlComponent) !== ControlComponent.POST_TEXT)) {
21551
+ continue;
21552
+ }
21553
+ } else if ((options == null ? void 0 : options.position) === LocationPosition.OUTER_BEFORE) {
21554
+ curIndex -= 1;
21555
+ } else if ((options == null ? void 0 : options.position) === LocationPosition.AFTER) {
21514
21556
  curIndex -= 1;
21515
21557
  if (element.controlComponent !== ControlComponent.PLACEHOLDER && element.controlComponent !== ControlComponent.POSTFIX && element.controlComponent !== ControlComponent.POST_TEXT) {
21516
21558
  continue;
21517
21559
  }
21518
21560
  } else {
21519
- if (element.controlComponent !== ControlComponent.PREFIX && element.controlComponent !== ControlComponent.PRE_TEXT || ((_a = elementList[i]) == null ? void 0 : _a.controlComponent) === ControlComponent.PREFIX || ((_b = elementList[i]) == null ? void 0 : _b.controlComponent) === ControlComponent.PRE_TEXT) {
21561
+ if (element.controlComponent !== ControlComponent.PREFIX && element.controlComponent !== ControlComponent.PRE_TEXT || ((_b = elementList[i]) == null ? void 0 : _b.controlComponent) === ControlComponent.PREFIX || ((_c = elementList[i]) == null ? void 0 : _c.controlComponent) === ControlComponent.PRE_TEXT) {
21520
21562
  continue;
21521
21563
  }
21522
21564
  }