@hailin-zheng/editor-core 2.2.20 → 2.2.22
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/editor.css +87 -146
- package/index-cjs.js +1099 -544
- package/index-cjs.js.map +1 -1
- package/index.js +1100 -545
- package/index.js.map +1 -1
- package/med_editor/doc-editor.d.ts +2 -1
- package/med_editor/doc-rule.d.ts +147 -19
- package/med_editor/framework/code-interpreter/dynamic-execute.d.ts +4 -1
- package/med_editor/framework/doc-layout/paragraph-arrange.d.ts +6 -3
- package/med_editor/framework/document-change.d.ts +1 -1
- package/med_editor/framework/document-context.d.ts +2 -2
- package/med_editor/framework/element-define.d.ts +5 -4
- package/med_editor/framework/element-props.d.ts +2 -1
- package/med_editor/framework/element-serialize.d.ts +1 -1
- package/med_editor/framework/impl/data-element/data-element-base-impl.d.ts +1 -1
- package/med_editor/framework/impl/document/doc-impl.d.ts +7 -0
- package/med_editor/framework/search/search-panel.d.ts +31 -0
- package/med_editor/framework/selection/selection-overlays.d.ts +5 -1
- package/med_editor/framework/util/common-util.d.ts +1 -0
- package/med_editor/framework/util/element-util.d.ts +19 -8
- package/package.json +2 -2
package/index-cjs.js
CHANGED
@@ -365,7 +365,9 @@ class BranchRenderObject extends RenderObject {
|
|
365
365
|
if (index < 0) {
|
366
366
|
throw new Error('为查找到当前元素');
|
367
367
|
}
|
368
|
-
if (child.parent === this)
|
368
|
+
if (child.parent === this) {
|
369
|
+
child.parent = null;
|
370
|
+
}
|
369
371
|
this.children.splice(index, 1);
|
370
372
|
}
|
371
373
|
removeChildByIndex(index) {
|
@@ -800,6 +802,14 @@ class CommonUtil {
|
|
800
802
|
}
|
801
803
|
return val;
|
802
804
|
}
|
805
|
+
static getKeyCombination(event) {
|
806
|
+
// 构建键盘组合字符串,包括修饰键
|
807
|
+
const modifiers = [event.ctrlKey ? "Ctrl" : "", event.shiftKey ? "Shift" : "", event.altKey ? "Alt" : "", event.metaKey ? "Meta" : ""].filter(Boolean).join("+");
|
808
|
+
// 根据修饰键的存在构建最终的键盘组合字符串
|
809
|
+
const key = event.key; // 直接使用 event.key 来获取按键实际字符
|
810
|
+
const keyCombination = modifiers.length > 0 ? `${modifiers}+${key}` : key;
|
811
|
+
return keyCombination;
|
812
|
+
}
|
803
813
|
}
|
804
814
|
|
805
815
|
const docOpsMap = new Map();
|
@@ -1278,6 +1288,7 @@ class Element {
|
|
1278
1288
|
//加载完毕
|
1279
1289
|
loaded;
|
1280
1290
|
visibleExpr;
|
1291
|
+
effectExpr;
|
1281
1292
|
attribute;
|
1282
1293
|
_parent;
|
1283
1294
|
get parent() {
|
@@ -1322,6 +1333,8 @@ class Element {
|
|
1322
1333
|
this.cacheRender = null;
|
1323
1334
|
this.unsubscribe(this);
|
1324
1335
|
this.disposed = true;
|
1336
|
+
this.visibleExpr = null;
|
1337
|
+
this.effectExpr = null;
|
1325
1338
|
}
|
1326
1339
|
addEvent(event, handle, useCapture = false) {
|
1327
1340
|
if (!this._eventMap) {
|
@@ -1413,24 +1426,41 @@ class LeafElement extends Element {
|
|
1413
1426
|
return 1;
|
1414
1427
|
}
|
1415
1428
|
pubOnChange(selfChange) {
|
1416
|
-
|
1417
|
-
|
1418
|
-
|
1419
|
-
|
1420
|
-
|
1421
|
-
|
1422
|
-
|
1423
|
-
|
1424
|
-
|
1425
|
-
|
1426
|
-
|
1427
|
-
|
1428
|
-
|
1429
|
-
}
|
1430
|
-
else {
|
1431
|
-
|
1432
|
-
}
|
1433
|
-
this._onChangeEvent.next();
|
1429
|
+
invokeRefresh(this, selfChange);
|
1430
|
+
// if (this.modifyFlag === ModifyFlag.None) {
|
1431
|
+
// this.refreshView();
|
1432
|
+
// }
|
1433
|
+
// if (this.modifyFlag === ModifyFlag.Track && selfChange === 'tracker') {
|
1434
|
+
// return;
|
1435
|
+
// }
|
1436
|
+
// if (this.modifyFlag === ModifyFlag.Modify) {
|
1437
|
+
// return;
|
1438
|
+
// }
|
1439
|
+
// if (selfChange === 'tracker') {
|
1440
|
+
// if (this.modifyFlag === ModifyFlag.None) {
|
1441
|
+
// this.modifyFlag = ModifyFlag.Track;
|
1442
|
+
// }
|
1443
|
+
// } else {
|
1444
|
+
// this.modifyFlag = ModifyFlag.Modify;
|
1445
|
+
// }
|
1446
|
+
// this._onChangeEvent.next();
|
1447
|
+
}
|
1448
|
+
}
|
1449
|
+
function invokeRefresh(ele, type) {
|
1450
|
+
const doc = getParent(ele, (item) => item.type === 'doc');
|
1451
|
+
if (doc) {
|
1452
|
+
doc.invokeChange(ele, type);
|
1453
|
+
}
|
1454
|
+
}
|
1455
|
+
function getParent(child, predicate) {
|
1456
|
+
if (!child) {
|
1457
|
+
return null;
|
1458
|
+
}
|
1459
|
+
if (predicate(child)) {
|
1460
|
+
return child;
|
1461
|
+
}
|
1462
|
+
else {
|
1463
|
+
return getParent(child.parent, predicate);
|
1434
1464
|
}
|
1435
1465
|
}
|
1436
1466
|
/**
|
@@ -1455,10 +1485,10 @@ class BranchElement extends Element {
|
|
1455
1485
|
//const refSub = child.refreshSubject.subscribe((data) => {
|
1456
1486
|
//this.refreshSubject.next(data);
|
1457
1487
|
// });
|
1458
|
-
const onChangeSub = child.onChangeSubject.subscribe((data) => {
|
1459
|
-
|
1460
|
-
});
|
1461
|
-
this.addsubscribe(child, onChangeSub);
|
1488
|
+
// const onChangeSub = child.onChangeSubject.subscribe((data) => {
|
1489
|
+
// this.pubOnChange('tracker');
|
1490
|
+
// });
|
1491
|
+
//this.addsubscribe(child, onChangeSub);
|
1462
1492
|
this.pubOnChange('self');
|
1463
1493
|
}
|
1464
1494
|
removeChild(child) {
|
@@ -1577,25 +1607,25 @@ class BranchElement extends Element {
|
|
1577
1607
|
return null;
|
1578
1608
|
}
|
1579
1609
|
pubOnChange(selfChange) {
|
1580
|
-
if (this.modifyFlag ===
|
1581
|
-
|
1582
|
-
}
|
1583
|
-
if (this.modifyFlag ===
|
1584
|
-
|
1585
|
-
}
|
1586
|
-
if (selfChange === 'tracker') {
|
1587
|
-
|
1588
|
-
|
1589
|
-
|
1590
|
-
}
|
1591
|
-
|
1592
|
-
|
1593
|
-
|
1594
|
-
|
1595
|
-
|
1596
|
-
|
1597
|
-
|
1598
|
-
this
|
1610
|
+
// if (this.modifyFlag === ModifyFlag.Track && selfChange === 'tracker') {
|
1611
|
+
// return;
|
1612
|
+
// }
|
1613
|
+
// if (this.modifyFlag === ModifyFlag.Modify) {
|
1614
|
+
// return;
|
1615
|
+
// }
|
1616
|
+
// if (selfChange === 'tracker') {
|
1617
|
+
// if (this.modifyFlag === ModifyFlag.None) {
|
1618
|
+
// this.modifyFlag = ModifyFlag.Track;
|
1619
|
+
// }
|
1620
|
+
// } else {
|
1621
|
+
// this.modifyFlag = ModifyFlag.Modify;
|
1622
|
+
// //clearChildrenRenderCache(this);
|
1623
|
+
// for (let i = 0; i < this.length; i++) {
|
1624
|
+
// this.getChild(i).pubOnChange('to-child')
|
1625
|
+
// }
|
1626
|
+
// }
|
1627
|
+
// this._onChangeEvent.next();
|
1628
|
+
invokeRefresh(this, selfChange);
|
1599
1629
|
}
|
1600
1630
|
}
|
1601
1631
|
function clearChildrenRenderCache(ele) {
|
@@ -1787,8 +1817,6 @@ class ViewOptions {
|
|
1787
1817
|
trackInsColor = '#ff4d4f';
|
1788
1818
|
//删除-留痕块文本颜色
|
1789
1819
|
trackDelColor = '#000';
|
1790
|
-
showLineRect;
|
1791
|
-
showCharRect;
|
1792
1820
|
showTabChar;
|
1793
1821
|
showSpaceChar;
|
1794
1822
|
showLineBreak;
|
@@ -1796,7 +1824,6 @@ class ViewOptions {
|
|
1796
1824
|
devMode = false;
|
1797
1825
|
showParaSymbol = true;
|
1798
1826
|
showDebug;
|
1799
|
-
resourceMode = 'immediate';
|
1800
1827
|
secretBrowse = false;
|
1801
1828
|
//中文版式,处理中文换行;前置标点和后置标点
|
1802
1829
|
chineseLayout = true;
|
@@ -1829,7 +1856,7 @@ class ViewOptions {
|
|
1829
1856
|
return;
|
1830
1857
|
}
|
1831
1858
|
this._fullPageView = value;
|
1832
|
-
this.onChange.next(
|
1859
|
+
this.onChange.next();
|
1833
1860
|
}
|
1834
1861
|
//毫米和像素的转换比
|
1835
1862
|
mmToPixelsRatio = 3.7795001220703126;
|
@@ -1878,7 +1905,7 @@ class ViewOptions {
|
|
1878
1905
|
return;
|
1879
1906
|
}
|
1880
1907
|
this._showTrackChanges = value;
|
1881
|
-
this.onChange.next(
|
1908
|
+
this.onChange.next();
|
1882
1909
|
}
|
1883
1910
|
get showTrackChangesTip() {
|
1884
1911
|
return this._showTrackChangesTip;
|
@@ -1888,7 +1915,7 @@ class ViewOptions {
|
|
1888
1915
|
return;
|
1889
1916
|
}
|
1890
1917
|
this._showTrackChangesTip = value;
|
1891
|
-
this.onChange.next(
|
1918
|
+
this.onChange.next();
|
1892
1919
|
}
|
1893
1920
|
//医嘱打印模式,文字行模式,将表格多行对象转换为多个表格行对象
|
1894
1921
|
textRowLineMode = false;
|
@@ -2958,7 +2985,7 @@ class DataDecorateElement extends LeafElement {
|
|
2958
2985
|
}
|
2959
2986
|
}
|
2960
2987
|
});
|
2961
|
-
this.disableClick = !isPrefix;
|
2988
|
+
//this.disableClick = !isPrefix;
|
2962
2989
|
this.isDecorate = true;
|
2963
2990
|
}
|
2964
2991
|
createRenderObject(data) {
|
@@ -3064,6 +3091,9 @@ function parser(code, objects) {
|
|
3064
3091
|
if (child.type === 'Identifier') {
|
3065
3092
|
const identifierName = child['name'];
|
3066
3093
|
if (identifierName.startsWith('$')) {
|
3094
|
+
//获取对象为"CallExpression", "MemberExpression"获取属性,例如$1.value
|
3095
|
+
parent?.type;
|
3096
|
+
`getObject('${identifierName.slice(1)})`;
|
3067
3097
|
child['name'] = `getObject('${identifierName.slice(1)}').value`;
|
3068
3098
|
objects?.push(identifierName.slice(1));
|
3069
3099
|
}
|
@@ -3090,6 +3120,11 @@ function parser(code, objects) {
|
|
3090
3120
|
}
|
3091
3121
|
}
|
3092
3122
|
});
|
3123
|
+
if (objects) {
|
3124
|
+
const set = new Set(objects);
|
3125
|
+
objects.length = 0;
|
3126
|
+
objects.push(...set);
|
3127
|
+
}
|
3093
3128
|
return astring.generate(node);
|
3094
3129
|
}
|
3095
3130
|
//判断代码的语句,如果最后一个语句不是return,那么加上return
|
@@ -3655,6 +3690,48 @@ class DocumentElement extends BlockContainerElement {
|
|
3655
3690
|
}
|
3656
3691
|
}
|
3657
3692
|
}
|
3693
|
+
onRefreshEvent = new Subject();
|
3694
|
+
/**
|
3695
|
+
* 元素内容或者属性发生改变,需要根据当前节点所在的树路径,设置脏标记,同时触发渲染
|
3696
|
+
* @param ele
|
3697
|
+
*/
|
3698
|
+
invokeChange(ele) {
|
3699
|
+
const parents = ElementUtil.getParentElements(ele);
|
3700
|
+
const pubLeafEle = (ele, eleChangeType) => {
|
3701
|
+
if (ele.modifyFlag === exports.ModifyFlag.Track && eleChangeType === 'tracker') {
|
3702
|
+
return;
|
3703
|
+
}
|
3704
|
+
if (ele.modifyFlag === exports.ModifyFlag.Modify) {
|
3705
|
+
return;
|
3706
|
+
}
|
3707
|
+
if (eleChangeType === 'tracker') {
|
3708
|
+
if (ele.modifyFlag === exports.ModifyFlag.None) {
|
3709
|
+
ele.modifyFlag = exports.ModifyFlag.Track;
|
3710
|
+
}
|
3711
|
+
}
|
3712
|
+
else {
|
3713
|
+
ele.modifyFlag = exports.ModifyFlag.Modify;
|
3714
|
+
if (ele instanceof BranchElement) {
|
3715
|
+
for (let i = 0; i < ele.length; i++) {
|
3716
|
+
const child = ele.getChild(i);
|
3717
|
+
if (child instanceof LeafElement) {
|
3718
|
+
pubLeafEle(child, 'to-child');
|
3719
|
+
}
|
3720
|
+
else if (child instanceof BranchElement) {
|
3721
|
+
pubLeafEle(child, 'to-child');
|
3722
|
+
}
|
3723
|
+
//this.getChild(i).pubOnChange('to-child')
|
3724
|
+
}
|
3725
|
+
}
|
3726
|
+
}
|
3727
|
+
};
|
3728
|
+
pubLeafEle(ele, 'self');
|
3729
|
+
for (let i = 1; i < parents.length; i++) {
|
3730
|
+
const parent = parents[i];
|
3731
|
+
pubLeafEle(parent, 'tracker');
|
3732
|
+
}
|
3733
|
+
this.onRefreshEvent.next();
|
3734
|
+
}
|
3658
3735
|
}
|
3659
3736
|
class DocumentRenderObject extends BlockContainerRenderObject {
|
3660
3737
|
constructor(ele) {
|
@@ -4056,7 +4133,7 @@ class DataElementInlineGroup extends InlineGroupInputElement {
|
|
4056
4133
|
}
|
4057
4134
|
parserExpress;
|
4058
4135
|
/**
|
4059
|
-
*
|
4136
|
+
* 解析表达式
|
4060
4137
|
* @param ele
|
4061
4138
|
* @param execute
|
4062
4139
|
* @private
|
@@ -4075,6 +4152,11 @@ class DataElementInlineGroup extends InlineGroupInputElement {
|
|
4075
4152
|
const depEleMap = new Map();
|
4076
4153
|
let compliedCode = parser(this.props.expression, depIdItems);
|
4077
4154
|
compliedCode = addReturn(compliedCode);
|
4155
|
+
this.parserExpress = {
|
4156
|
+
compliedCode,
|
4157
|
+
func: new Function(`with(this){ ${compliedCode} }`),
|
4158
|
+
depItems: depEleMap
|
4159
|
+
};
|
4078
4160
|
if (depIdItems.length) {
|
4079
4161
|
depIdItems.forEach(dep => {
|
4080
4162
|
const refCtx = execute.getObject(dep);
|
@@ -4084,19 +4166,34 @@ class DataElementInlineGroup extends InlineGroupInputElement {
|
|
4084
4166
|
//当前有可能是checkbox数组
|
4085
4167
|
const refEles = Array.isArray(refEle) ? refEle : [refEle];
|
4086
4168
|
reactiveMode && refEles.forEach(item => {
|
4169
|
+
//避免死循环调用
|
4170
|
+
if (item === this) {
|
4171
|
+
return;
|
4172
|
+
}
|
4087
4173
|
//求值依赖元素更改的时候,发布当前元素重新计算的指令
|
4088
4174
|
item.onChangeSubject.subscribe(() => {
|
4089
|
-
this.pubOnChange('self');
|
4175
|
+
//this.pubOnChange('self');
|
4176
|
+
try {
|
4177
|
+
data.onNextView(() => {
|
4178
|
+
//当前元素可能被删除
|
4179
|
+
const func = this.parserExpress.func;
|
4180
|
+
if (!func) {
|
4181
|
+
return;
|
4182
|
+
}
|
4183
|
+
const tempExecuter = execute.create();
|
4184
|
+
tempExecuter.setCurrentCtx(this, this.parserExpress.depItems);
|
4185
|
+
const fn = func.bind(tempExecuter);
|
4186
|
+
fn();
|
4187
|
+
});
|
4188
|
+
}
|
4189
|
+
catch (e) {
|
4190
|
+
console.error(e, "表达式执行出错", this.parserExpress.compliedCode);
|
4191
|
+
}
|
4090
4192
|
});
|
4091
4193
|
});
|
4092
4194
|
}
|
4093
4195
|
});
|
4094
4196
|
}
|
4095
|
-
this.parserExpress = {
|
4096
|
-
compliedCode,
|
4097
|
-
func: new Function(`with(this){ ${compliedCode} }`),
|
4098
|
-
depItems: depEleMap
|
4099
|
-
};
|
4100
4197
|
}
|
4101
4198
|
catch (e) {
|
4102
4199
|
console.error('解析表达式出错,parseEleExpression', this.props.expression);
|
@@ -4240,7 +4337,11 @@ function exportDataEleDecoratorSVG$1(event, r) {
|
|
4240
4337
|
if (['all', 'outline'].includes(mode)) {
|
4241
4338
|
color = event.options.dataEleOutlineColor;
|
4242
4339
|
const verOffset = 0;
|
4243
|
-
const
|
4340
|
+
const currParaGroupRenders = getCurrentParaGroupRenders(r);
|
4341
|
+
if (currParaGroupRenders.indexOf(r) !== 0) {
|
4342
|
+
return;
|
4343
|
+
}
|
4344
|
+
const renderPosMap = currParaGroupRenders.map(item => ({ pos: getRenderPosToDoc(item), render: item }));
|
4244
4345
|
if (renderPosMap.length > 1) {
|
4245
4346
|
const secondGroupRenderPos = renderPosMap[1].pos;
|
4246
4347
|
if (secondGroupRenderPos.x + renderPosMap[1].render.rect.width > event.relativePagePos.x) {
|
@@ -4547,20 +4648,25 @@ class PSymbolRenderObject extends LeafRenderObject {
|
|
4547
4648
|
if (!event.options.showEnterSymbol || event.mode === 'print') {
|
4548
4649
|
return null;
|
4549
4650
|
}
|
4550
|
-
const font = `14px
|
4551
|
-
const actualFontBoundingBoxAscent = event.renderCtx.mainContext.getActualFontBoundingBoxAscent(font);
|
4651
|
+
// const font = `14px system-ui`
|
4652
|
+
// const actualFontBoundingBoxAscent = event.renderCtx.mainContext.getActualFontBoundingBoxAscent(font);
|
4552
4653
|
let y = this.rect.y;
|
4553
|
-
//基线处理
|
4554
|
-
y += actualFontBoundingBoxAscent ?? 0;
|
4555
|
-
//行高处理
|
4654
|
+
// //基线处理
|
4655
|
+
//y += actualFontBoundingBoxAscent ?? 0;
|
4656
|
+
// //行高处理
|
4556
4657
|
y += (this.rect.height - 14) / 2;
|
4557
|
-
return
|
4558
|
-
|
4559
|
-
|
4560
|
-
|
4561
|
-
|
4562
|
-
|
4563
|
-
|
4658
|
+
return {
|
4659
|
+
sel: 'image',
|
4660
|
+
data: {
|
4661
|
+
ns: 'http://www.w3.org/2000/svg',
|
4662
|
+
attrs: {
|
4663
|
+
translate: { x: this.rect.x, y: y },
|
4664
|
+
width: 7,
|
4665
|
+
height: 7,
|
4666
|
+
href: "",
|
4667
|
+
}
|
4668
|
+
}
|
4669
|
+
};
|
4564
4670
|
}
|
4565
4671
|
//绘制段落符号
|
4566
4672
|
clone() {
|
@@ -8800,26 +8906,32 @@ class BreakRenderObject extends LeafRenderObject {
|
|
8800
8906
|
if (!event.options.showEnterSymbol || event.mode === 'print') {
|
8801
8907
|
return null;
|
8802
8908
|
}
|
8803
|
-
//
|
8804
|
-
//
|
8805
|
-
|
8806
|
-
//
|
8807
|
-
//
|
8808
|
-
//
|
8809
|
-
|
8810
|
-
|
8811
|
-
|
8812
|
-
|
8813
|
-
|
8814
|
-
|
8815
|
-
|
8816
|
-
|
8817
|
-
|
8818
|
-
|
8819
|
-
|
8820
|
-
|
8821
|
-
|
8822
|
-
|
8909
|
+
// const font = `14px system-ui`
|
8910
|
+
// const actualFontBoundingBoxAscent = event.renderCtx.mainContext.getActualFontBoundingBoxAscent(font);
|
8911
|
+
let y = this.rect.y;
|
8912
|
+
// return {
|
8913
|
+
// sel: 'path',
|
8914
|
+
// data: {
|
8915
|
+
// ns: 'http://www.w3.org/2000/svg',
|
8916
|
+
// attrs: {
|
8917
|
+
// stroke: 'none',
|
8918
|
+
// fill: 'blue',
|
8919
|
+
// d: path,
|
8920
|
+
// translate: { x: this.rect.x, y: y }
|
8921
|
+
// }
|
8922
|
+
// }
|
8923
|
+
// }
|
8924
|
+
return {
|
8925
|
+
sel: 'image',
|
8926
|
+
data: {
|
8927
|
+
ns: 'http://www.w3.org/2000/svg',
|
8928
|
+
attrs: {
|
8929
|
+
translate: { x: this.rect.x, y: y + (this.rect.height - 10) / 2 },
|
8930
|
+
height: 10,
|
8931
|
+
href: "",
|
8932
|
+
}
|
8933
|
+
}
|
8934
|
+
};
|
8823
8935
|
}
|
8824
8936
|
clone() {
|
8825
8937
|
const render = new BreakRenderObject(this.element);
|
@@ -8883,7 +8995,7 @@ class DataElementGroupElement extends InlineGroupInputElement {
|
|
8883
8995
|
}
|
8884
8996
|
}
|
8885
8997
|
getValue() {
|
8886
|
-
return ElementSerialize.serializeString(this
|
8998
|
+
return ElementSerialize.serializeString(this);
|
8887
8999
|
}
|
8888
9000
|
clone(data) {
|
8889
9001
|
return super.cloneSelf(data, DataElementGroupElement);
|
@@ -8988,15 +9100,29 @@ function exportDataEleDecoratorSVG(event, r) {
|
|
8988
9100
|
return;
|
8989
9101
|
}
|
8990
9102
|
//绘制背景
|
8991
|
-
if (['all', 'background'].includes(mode)) {
|
8992
|
-
|
8993
|
-
|
8994
|
-
|
8995
|
-
}
|
8996
|
-
if (['all', 'outline'].includes(mode)) {
|
8997
|
-
|
9103
|
+
// if (['all', 'background'].includes(mode)) {
|
9104
|
+
// const bgX = event.relativePagePos.x;
|
9105
|
+
// const bgY = event.relativePagePos.y;
|
9106
|
+
// event.highlights.push(ElementUtil.getFillSvgRect(bgX, bgY, r.rect.width, r.rect.height, color));
|
9107
|
+
// }
|
9108
|
+
if (['all', 'outline', 'background'].includes(mode)) {
|
9109
|
+
let outlineColor = ['all', 'outline'].includes(mode) ? event.options.dataGroupOutlineColor : 'none';
|
9110
|
+
let bgColor = ['all', 'background'].includes(mode) ? color : 'none';
|
8998
9111
|
const verOffset = 0;
|
8999
|
-
const
|
9112
|
+
const currParaGroupRenders = getCurrentParaGroupRenders(r);
|
9113
|
+
if (currParaGroupRenders.indexOf(r) === 0) {
|
9114
|
+
outlineColor = 'none';
|
9115
|
+
}
|
9116
|
+
if (currParaGroupRenders.indexOf(r) === currParaGroupRenders.length - 1) {
|
9117
|
+
bgColor = 'none';
|
9118
|
+
}
|
9119
|
+
if (bgColor !== 'none' && currParaGroupRenders.indexOf(r) !== 0) {
|
9120
|
+
return;
|
9121
|
+
}
|
9122
|
+
if (outlineColor !== 'none' && currParaGroupRenders.indexOf(r) !== currParaGroupRenders.length - 1) {
|
9123
|
+
return;
|
9124
|
+
}
|
9125
|
+
const renderPosMap = currParaGroupRenders.map(item => ({ pos: getRenderPosToDoc(item), render: item }));
|
9000
9126
|
if (renderPosMap.length > 1) {
|
9001
9127
|
const secondGroupRenderPos = renderPosMap[1].pos;
|
9002
9128
|
if (secondGroupRenderPos.x + renderPosMap[1].render.rect.width > event.relativePagePos.x) {
|
@@ -9024,8 +9150,8 @@ function exportDataEleDecoratorSVG(event, r) {
|
|
9024
9150
|
const path = [...sharpPoints, ...sharpPoints1, sharpPoints[0]].map((item, index) => ((index === 0) ? 'M' : "L") + item.x + " " + item.y).join(" ");
|
9025
9151
|
event.highlights.push(ElementUtil.createSvgPath({
|
9026
9152
|
d: path,
|
9027
|
-
stroke:
|
9028
|
-
fill:
|
9153
|
+
stroke: outlineColor,
|
9154
|
+
fill: bgColor,
|
9029
9155
|
'stroke-width': 1
|
9030
9156
|
}));
|
9031
9157
|
return;
|
@@ -9035,8 +9161,8 @@ function exportDataEleDecoratorSVG(event, r) {
|
|
9035
9161
|
const currRen = renderPosMap[i];
|
9036
9162
|
event.highlights.push(ElementUtil.createSvgPath({
|
9037
9163
|
d: `M${currRen.pos.x} ${currRen.pos.y} L${currRen.pos.x + currRen.render.rect.width} ${currRen.pos.y} L${currRen.pos.x + currRen.render.rect.width} ${currRen.pos.y + currRen.render.rect.height} L${currRen.pos.x} ${currRen.pos.y + currRen.render.rect.height} Z`,
|
9038
|
-
stroke:
|
9039
|
-
fill:
|
9164
|
+
stroke: outlineColor,
|
9165
|
+
fill: bgColor,
|
9040
9166
|
'stroke-width': 1
|
9041
9167
|
}));
|
9042
9168
|
}
|
@@ -9291,7 +9417,7 @@ class DataElementText extends DataElementInlineGroup {
|
|
9291
9417
|
createRenderObject(data) {
|
9292
9418
|
if (data.options.enableDyExpression) {
|
9293
9419
|
this.parseEleExpression(data);
|
9294
|
-
this.evalEleExpr(data.execute)
|
9420
|
+
//this.evalEleExpr(data.execute)
|
9295
9421
|
}
|
9296
9422
|
return new DataElementTextRenderObject(this);
|
9297
9423
|
}
|
@@ -9341,7 +9467,7 @@ class DataElementText extends DataElementInlineGroup {
|
|
9341
9467
|
this.onChangedValidate();
|
9342
9468
|
}
|
9343
9469
|
getValue() {
|
9344
|
-
return ElementSerialize.serializeString(this
|
9470
|
+
return ElementSerialize.serializeString(this);
|
9345
9471
|
}
|
9346
9472
|
validate() {
|
9347
9473
|
let error = super.validate();
|
@@ -10944,8 +11070,8 @@ class ElementSerialize {
|
|
10944
11070
|
}
|
10945
11071
|
return result;
|
10946
11072
|
}
|
10947
|
-
static serializeString(element, options = {
|
10948
|
-
if (!options.
|
11073
|
+
static serializeString(element, options = { includeRunDel: false }) {
|
11074
|
+
if (!options.includeRunDel && element instanceof TrackRunElement && element.type === exports.TrackRunTypeEnum.Deleted) {
|
10949
11075
|
return '';
|
10950
11076
|
}
|
10951
11077
|
if (element instanceof TextGroupElement && !element.isDecorate) {
|
@@ -11082,7 +11208,7 @@ class TrackRunElement extends InlineGroupElement {
|
|
11082
11208
|
trackRunType: this.type,
|
11083
11209
|
name: this.props.userName,
|
11084
11210
|
date: this.props.date,
|
11085
|
-
content: ElementSerialize.serializeString(this, {
|
11211
|
+
content: ElementSerialize.serializeString(this, { includeRunDel: true })
|
11086
11212
|
};
|
11087
11213
|
console.log(evt.trackTips.content);
|
11088
11214
|
evt.isCancel = true;
|
@@ -11182,7 +11308,7 @@ class TrackRunRenderObject extends InlineGroupRenderObject {
|
|
11182
11308
|
const { x, y } = event.globalPos;
|
11183
11309
|
const docRender = ElementUtil.getParentRender(this, DocumentRenderObject);
|
11184
11310
|
const opType = this.element.type === 'ins-run' ? '插入:' : '删除:';
|
11185
|
-
const content = ElementSerialize.serializeString(this.element, {
|
11311
|
+
const content = ElementSerialize.serializeString(this.element, { includeRunDel: true });
|
11186
11312
|
let left = this.element.gotFocus ? -10 : 5;
|
11187
11313
|
//显示在文档的右测
|
11188
11314
|
left += docRender.rect.x + docRender.rect.width + 20;
|
@@ -12322,54 +12448,87 @@ class ElementUtil {
|
|
12322
12448
|
/**
|
12323
12449
|
* 递归向前寻找最近的元素
|
12324
12450
|
* @param currElement
|
12325
|
-
* @param inPara 是否在同一段落中寻找
|
12326
|
-
* @param forCursor 查找结果是否用于光标定位
|
12327
12451
|
* @param viewOptions
|
12328
12452
|
* @returns
|
12329
12453
|
*/
|
12330
|
-
static getRecursionPrevSiblingElement(currElement,
|
12454
|
+
static getRecursionPrevSiblingElement(currElement, viewOptions) {
|
12331
12455
|
const parent = currElement?.parent;
|
12332
12456
|
//删除留痕块的measureRender在不显示留痕模式下,不生成render
|
12333
|
-
if (!currElement || !parent ||
|
12457
|
+
if (!currElement || !parent || !currElement.paintRenders.length) {
|
12334
12458
|
return null;
|
12335
12459
|
}
|
12336
12460
|
//如果当前数据元不可编辑,则直接跳过
|
12337
|
-
|
12338
|
-
|
12339
|
-
|
12340
|
-
|
12341
|
-
|
12342
|
-
|
12461
|
+
//不存在这种情况
|
12462
|
+
// if (parent instanceof DataElementInlineGroup && !parent.props.editable && viewOptions.docMode === DocMode.FormEdit) {
|
12463
|
+
// return this.getRecursionPrevSiblingElement(parent, inPara, viewOptions);
|
12464
|
+
// }
|
12465
|
+
//不存在这种情况
|
12466
|
+
// if (parent.disableClick) {
|
12467
|
+
// return this.getRecursionPrevSiblingElement(parent, inPara, viewOptions);
|
12468
|
+
// }
|
12343
12469
|
const index = parent.getChildIndex(currElement);
|
12344
|
-
if (!index) {
|
12345
|
-
|
12346
|
-
|
12470
|
+
// if (!index) {
|
12471
|
+
// if (inPara && parent.type === 'p') {
|
12472
|
+
// return null;
|
12473
|
+
// }
|
12474
|
+
// return this.getRecursionPrevSiblingElement(parent, inPara, viewOptions);
|
12475
|
+
// } else {
|
12476
|
+
let prevElement = null;
|
12477
|
+
for (let i = index - 1; i >= 0; i--) {
|
12478
|
+
prevElement = parent.getChild(i);
|
12479
|
+
const res = this.getRecursionSiblingElementCursorPosition(prevElement, viewOptions, 'left');
|
12480
|
+
if (res) {
|
12481
|
+
return res;
|
12347
12482
|
}
|
12348
|
-
return this.getRecursionPrevSiblingElement(parent, inPara, forCursor, viewOptions);
|
12349
12483
|
}
|
12350
|
-
|
12351
|
-
|
12352
|
-
|
12353
|
-
|
12354
|
-
|
12355
|
-
|
12484
|
+
//表单模式需要判断当前父级是否已经超出数据元或者数据组的范围
|
12485
|
+
if (viewOptions.docMode === exports.DocMode.FormEdit && !ElementUtil.getDataGroupElement(parent)) {
|
12486
|
+
return null;
|
12487
|
+
}
|
12488
|
+
return this.getRecursionPrevSiblingElement(parent, viewOptions);
|
12489
|
+
//}
|
12490
|
+
}
|
12491
|
+
/**
|
12492
|
+
* 递归元素里面向前寻找可以定位的元素
|
12493
|
+
*/
|
12494
|
+
static getRecursionSiblingElementCursorPosition(ele, viewOptions, direction) {
|
12495
|
+
if (ele instanceof LeafElement) {
|
12496
|
+
return this.getElementPositionCursor(ele, viewOptions, direction);
|
12497
|
+
}
|
12498
|
+
if (ele instanceof BranchElement) {
|
12499
|
+
const startIndex = direction === 'left' ? ele.length - 1 : 0;
|
12500
|
+
const endIndex = direction === 'left' ? 0 : ele.length - 1;
|
12501
|
+
const increment = direction === 'left' ? -1 : 1;
|
12502
|
+
for (let i = startIndex; direction === 'left' ? i >= endIndex : i <= endIndex; i += increment) {
|
12503
|
+
const child = ele.getChild(i);
|
12504
|
+
if (child instanceof LeafElement) {
|
12505
|
+
const res = this.getElementPositionCursor(child, viewOptions, direction);
|
12506
|
+
if (res) {
|
12507
|
+
return res;
|
12508
|
+
}
|
12509
|
+
}
|
12510
|
+
else if (child instanceof BranchElement) {
|
12511
|
+
const res = this.getRecursionSiblingElementCursorPosition(child, viewOptions, direction);
|
12512
|
+
if (res) {
|
12513
|
+
return res;
|
12514
|
+
}
|
12356
12515
|
}
|
12357
12516
|
}
|
12358
|
-
|
12359
|
-
|
12360
|
-
|
12361
|
-
|
12362
|
-
|
12363
|
-
|
12364
|
-
|
12365
|
-
|
12366
|
-
|
12367
|
-
|
12368
|
-
|
12369
|
-
|
12370
|
-
return this.getRecursionPrevSiblingElement(prevElement.parent, inPara, forCursor, viewOptions);
|
12517
|
+
}
|
12518
|
+
return null;
|
12519
|
+
}
|
12520
|
+
static getElementPositionCursor(ele, viewOptions, direction) {
|
12521
|
+
const endOffset = ElementUtil.getElementEndOffset(ele);
|
12522
|
+
const offsets = direction === 'left' ? [endOffset, 0] : [0, endOffset];
|
12523
|
+
for (let i = 0; i < offsets.length; i++) {
|
12524
|
+
if (ElementUtil.canSetCursor(ele, offsets[i], true, viewOptions)) {
|
12525
|
+
return {
|
12526
|
+
ele: ele,
|
12527
|
+
offset: offsets[i]
|
12528
|
+
};
|
12371
12529
|
}
|
12372
12530
|
}
|
12531
|
+
return null;
|
12373
12532
|
}
|
12374
12533
|
/**
|
12375
12534
|
* 循环向前寻找可定位的数据元
|
@@ -12434,55 +12593,56 @@ class ElementUtil {
|
|
12434
12593
|
/**
|
12435
12594
|
* 递归向后寻找最近的元素
|
12436
12595
|
*/
|
12437
|
-
static getRecursionNextSiblingElement(currElement,
|
12596
|
+
static getRecursionNextSiblingElement(currElement, viewOptions) {
|
12438
12597
|
const parent = currElement?.parent;
|
12439
12598
|
if (!currElement || !parent) {
|
12440
12599
|
return null;
|
12441
12600
|
}
|
12442
|
-
//
|
12443
|
-
//
|
12601
|
+
// //如果当前数据元不可编辑,则直接跳过
|
12602
|
+
// if (parent instanceof DataElementInlineGroup && !parent.props.editable && viewOptions.docMode === DocMode.FormEdit) {
|
12603
|
+
// return this.getRecursionNextSiblingElement(parent, inPara, forCursor, viewOptions);
|
12604
|
+
// }
|
12605
|
+
// //如果当前为数据组,且数据组被隐藏,则直接跳过
|
12606
|
+
// if (parent instanceof DataElementGroupElement && parent.props.hidden) {
|
12607
|
+
// return this.getRecursionNextSiblingElement(parent, inPara, forCursor, viewOptions);
|
12608
|
+
// }
|
12609
|
+
// if (forCursor && parent.disableClick) {
|
12610
|
+
// return this.getRecursionNextSiblingElement(parent, inPara, forCursor, viewOptions);
|
12444
12611
|
// }
|
12445
|
-
//如果当前数据元不可编辑,则直接跳过
|
12446
|
-
if (parent instanceof DataElementInlineGroup && !parent.props.editable && viewOptions.docMode === exports.DocMode.FormEdit) {
|
12447
|
-
return this.getRecursionNextSiblingElement(parent, inPara, forCursor, viewOptions);
|
12448
|
-
}
|
12449
|
-
//如果当前为数据组,且数据组被隐藏,则直接跳过
|
12450
|
-
if (parent instanceof DataElementGroupElement && parent.props.hidden) {
|
12451
|
-
return this.getRecursionNextSiblingElement(parent, inPara, forCursor, viewOptions);
|
12452
|
-
}
|
12453
|
-
if (forCursor && parent.disableClick) {
|
12454
|
-
return this.getRecursionNextSiblingElement(parent, inPara, forCursor, viewOptions);
|
12455
|
-
}
|
12456
12612
|
const index = parent.getChildIndex(currElement);
|
12457
|
-
if (index === parent.length - 1) {
|
12458
|
-
|
12459
|
-
|
12613
|
+
// if (index === parent.length - 1) {
|
12614
|
+
// if (inPara && parent.type === 'p') {
|
12615
|
+
// return null;
|
12616
|
+
// }
|
12617
|
+
// return this.getRecursionNextSiblingElement(parent, inPara, forCursor, viewOptions);
|
12618
|
+
// } else {
|
12619
|
+
let nextElement = null;
|
12620
|
+
for (let i = index + 1; i < parent.length; i++) {
|
12621
|
+
nextElement = parent.getChild(i);
|
12622
|
+
const res = this.getRecursionSiblingElementCursorPosition(nextElement, viewOptions, 'right');
|
12623
|
+
if (res) {
|
12624
|
+
return res;
|
12460
12625
|
}
|
12461
|
-
return this.getRecursionNextSiblingElement(parent, inPara, forCursor, viewOptions);
|
12462
12626
|
}
|
12463
|
-
|
12464
|
-
|
12465
|
-
|
12466
|
-
nextElement = parent.getChild(i);
|
12467
|
-
if (nextElement && !nextElement.disableClick) {
|
12468
|
-
break;
|
12469
|
-
}
|
12470
|
-
}
|
12471
|
-
if (!nextElement || nextElement.disableClick) {
|
12472
|
-
return this.getRecursionNextSiblingElement(parent, inPara, forCursor, viewOptions);
|
12473
|
-
}
|
12474
|
-
const lastLeafElement = ElementUtil.getFirstLeafElement(nextElement);
|
12475
|
-
//用于光标定位
|
12476
|
-
if (forCursor && lastLeafElement && !ElementUtil.canSetCursor(lastLeafElement, ElementUtil.getElementEndOffset(lastLeafElement), true, viewOptions)) {
|
12477
|
-
return this.getRecursionNextSiblingElement(lastLeafElement, inPara, forCursor, viewOptions);
|
12478
|
-
}
|
12479
|
-
if (lastLeafElement) {
|
12480
|
-
return lastLeafElement;
|
12481
|
-
}
|
12482
|
-
else {
|
12483
|
-
return this.getRecursionNextSiblingElement(nextElement.parent, inPara, forCursor, viewOptions);
|
12484
|
-
}
|
12627
|
+
//表单模式需要判断当前父级是否已经超出数据元或者数据组的范围
|
12628
|
+
if (viewOptions.docMode === exports.DocMode.FormEdit && !ElementUtil.getDataGroupElement(parent)) {
|
12629
|
+
return null;
|
12485
12630
|
}
|
12631
|
+
return this.getRecursionNextSiblingElement(parent, viewOptions);
|
12632
|
+
// if (!nextElement || nextElement.disableClick) {
|
12633
|
+
// return this.getRecursionNextSiblingElement(parent, inPara, forCursor, viewOptions);
|
12634
|
+
// }
|
12635
|
+
// const lastLeafElement = ElementUtil.getFirstLeafElement(nextElement);
|
12636
|
+
// //用于光标定位
|
12637
|
+
// if (forCursor && lastLeafElement && !ElementUtil.canSetCursor(lastLeafElement, ElementUtil.getElementEndOffset(lastLeafElement), true, viewOptions)) {
|
12638
|
+
// return this.getRecursionNextSiblingElement(lastLeafElement, inPara, forCursor, viewOptions);
|
12639
|
+
// }
|
12640
|
+
// if (lastLeafElement) {
|
12641
|
+
// return lastLeafElement;
|
12642
|
+
// } else {
|
12643
|
+
// return this.getRecursionNextSiblingElement(nextElement.parent, inPara, forCursor, viewOptions);
|
12644
|
+
// }
|
12645
|
+
//}
|
12486
12646
|
}
|
12487
12647
|
// /**
|
12488
12648
|
// * 在同一段落中,递归向后寻找最近的元素
|
@@ -12799,10 +12959,10 @@ class ElementUtil {
|
|
12799
12959
|
return this.getParent(ele, item => item instanceof DataElementInlineGroup);
|
12800
12960
|
}
|
12801
12961
|
/**
|
12802
|
-
|
12803
|
-
|
12804
|
-
|
12805
|
-
|
12962
|
+
* 向上查找类型为数据元的父级
|
12963
|
+
* @param ele
|
12964
|
+
* @returns
|
12965
|
+
*/
|
12806
12966
|
static getDataGroupElement(ele) {
|
12807
12967
|
return this.getParent(ele, item => item instanceof DataElementGroupElement);
|
12808
12968
|
}
|
@@ -13041,6 +13201,9 @@ class ElementUtil {
|
|
13041
13201
|
}
|
13042
13202
|
return items;
|
13043
13203
|
}
|
13204
|
+
static isDataEle(ele) {
|
13205
|
+
return validateDataEle(ele) || ele instanceof DataElementGroupElement;
|
13206
|
+
}
|
13044
13207
|
}
|
13045
13208
|
|
13046
13209
|
exports.TextUnitsHolder = void 0;
|
@@ -13562,7 +13725,7 @@ class EditorContext {
|
|
13562
13725
|
// const docRefreshSub = this._document.refreshSubject.subscribe(() => {
|
13563
13726
|
// this.syncRefresh?.();
|
13564
13727
|
// });
|
13565
|
-
const docChangedSub = this._document.
|
13728
|
+
const docChangedSub = this._document.onRefreshEvent.subscribe(() => {
|
13566
13729
|
this.syncRefresh?.();
|
13567
13730
|
});
|
13568
13731
|
this.syncRefresh();
|
@@ -13679,20 +13842,17 @@ class DocumentContext {
|
|
13679
13842
|
this.ss = ss;
|
13680
13843
|
}
|
13681
13844
|
getControlIDList() {
|
13682
|
-
const dataEleList = this.ctx.treeFilter(item =>
|
13845
|
+
const dataEleList = this.ctx.treeFilter(item => ElementUtil.isDataEle(item));
|
13683
13846
|
return dataEleList.map(item => item.props.id);
|
13684
13847
|
}
|
13685
13848
|
getControlInstanceList(options) {
|
13686
|
-
return this.ctx.treeFilter(item =>
|
13849
|
+
return this.ctx.treeFilter(item => ElementUtil.isDataEle(item), options);
|
13687
13850
|
}
|
13688
13851
|
getControlById(id) {
|
13689
|
-
return this.ctx.treeFind(item =>
|
13690
|
-
}
|
13691
|
-
isDataEle(ele) {
|
13692
|
-
return validateDataEle(ele) || ele instanceof DataElementGroupElement;
|
13852
|
+
return this.ctx.treeFind(item => ElementUtil.isDataEle(item) && item['props']['id'] === id);
|
13693
13853
|
}
|
13694
13854
|
getControlByName(name) {
|
13695
|
-
return this.ctx.treeFind(item =>
|
13855
|
+
return this.ctx.treeFind(item => ElementUtil.isDataEle(item) && item['props']['name'] === name);
|
13696
13856
|
}
|
13697
13857
|
/**
|
13698
13858
|
* 获取数据元值集合
|
@@ -13710,9 +13870,9 @@ class DocumentContext {
|
|
13710
13870
|
* @returns
|
13711
13871
|
*/
|
13712
13872
|
getDataElementModelList(options) {
|
13713
|
-
const dataEleList = this.ctx.treeFilter(item =>
|
13873
|
+
const dataEleList = this.ctx.treeFilter(item => ElementUtil.isDataEle(item), options);
|
13714
13874
|
//数据元、数据组
|
13715
|
-
const dataInlineGroups = dataEleList.filter(item => item instanceof DataElementInlineGroup);
|
13875
|
+
const dataInlineGroups = dataEleList.filter(item => item instanceof DataElementInlineGroup || item instanceof DataElementGroupElement);
|
13716
13876
|
const dataLeafs = dataEleList.filter(item => item instanceof DataElementLeaf);
|
13717
13877
|
//复选框数据元
|
13718
13878
|
const dataCheckList = dataLeafs.filter(item => item instanceof DataElementCheck);
|
@@ -13721,6 +13881,7 @@ class DocumentContext {
|
|
13721
13881
|
id: item.props.id,
|
13722
13882
|
name: item.props.name,
|
13723
13883
|
fieldName: item.props.fieldName,
|
13884
|
+
caption: item.props.caption,
|
13724
13885
|
item,
|
13725
13886
|
getValue: () => {
|
13726
13887
|
return item.getValue();
|
@@ -13730,7 +13891,7 @@ class DocumentContext {
|
|
13730
13891
|
}
|
13731
13892
|
}));
|
13732
13893
|
const dataInlineStructList = dataInlineGroups.map(item => ({
|
13733
|
-
id: item.props.id, name: item.props.name, fieldName: item.props.fieldName, item, getValue: () => {
|
13894
|
+
id: item.props.id, name: item.props.name, fieldName: item.props.fieldName, caption: item.props.caption, item, getValue: () => {
|
13734
13895
|
return item.getValue();
|
13735
13896
|
}, setValue: (val) => {
|
13736
13897
|
item.setValue(val);
|
@@ -13757,6 +13918,7 @@ class DocumentContext {
|
|
13757
13918
|
name: groupCheckItems[0].props.name,
|
13758
13919
|
fieldName: groupCheckItems[0].props.fieldName,
|
13759
13920
|
multiSelect: groupCheckItems[0].props.multiSelect,
|
13921
|
+
caption: groupCheckItems[0].props.caption,
|
13760
13922
|
item: groupCheckItems,
|
13761
13923
|
getValue: () => {
|
13762
13924
|
let checkedValue = '';
|
@@ -13795,6 +13957,7 @@ class DocumentContext {
|
|
13795
13957
|
id: item.props.id,
|
13796
13958
|
name: item.props.name,
|
13797
13959
|
fieldName: item.props.fieldName,
|
13960
|
+
caption: item.props.caption,
|
13798
13961
|
item,
|
13799
13962
|
getValue: () => {
|
13800
13963
|
return item.getValue();
|
@@ -13821,7 +13984,7 @@ class DocumentContext {
|
|
13821
13984
|
const trackElements = this.getTrackElements();
|
13822
13985
|
return trackElements.map(item => {
|
13823
13986
|
const trackRun = item;
|
13824
|
-
const content = ElementSerialize.serializeString(trackRun, {
|
13987
|
+
const content = ElementSerialize.serializeString(trackRun, { includeRunDel: true });
|
13825
13988
|
return {
|
13826
13989
|
//用户id
|
13827
13990
|
userId: trackRun.props.userId,
|
@@ -13955,6 +14118,9 @@ class DynamicExecute {
|
|
13955
14118
|
this.doc = doc;
|
13956
14119
|
this.ss = ss;
|
13957
14120
|
}
|
14121
|
+
create() {
|
14122
|
+
return new DynamicExecute(this.doc, this.ss);
|
14123
|
+
}
|
13958
14124
|
setCurrentCtx(ele, depItems) {
|
13959
14125
|
this.current = ele;
|
13960
14126
|
this.depItems = depItems;
|
@@ -13964,10 +14130,10 @@ class DynamicExecute {
|
|
13964
14130
|
this.depItems = undefined;
|
13965
14131
|
}
|
13966
14132
|
cacheList;
|
13967
|
-
getControlById(id) {
|
14133
|
+
getControlById(id, options) {
|
13968
14134
|
if (!this.cacheList) {
|
13969
14135
|
const ctx = new DocumentContext(this.doc, this.ss);
|
13970
|
-
this.cacheList = ctx.getDataElementModelList();
|
14136
|
+
this.cacheList = ctx.getDataElementModelList(options);
|
13971
14137
|
}
|
13972
14138
|
const f = this.cacheList.find(item => item.id === id);
|
13973
14139
|
return f;
|
@@ -13982,7 +14148,7 @@ class DynamicExecute {
|
|
13982
14148
|
if (id.startsWith('$')) {
|
13983
14149
|
id = id.slice(1);
|
13984
14150
|
}
|
13985
|
-
const control = this.getControlById(id);
|
14151
|
+
const control = this.getControlById(id, { includeChildren: true });
|
13986
14152
|
return {
|
13987
14153
|
get value() {
|
13988
14154
|
if (control) {
|
@@ -14068,14 +14234,23 @@ class DynamicExecute {
|
|
14068
14234
|
}
|
14069
14235
|
|
14070
14236
|
class ParagraphMeasure {
|
14071
|
-
|
14237
|
+
docCtx;
|
14072
14238
|
renderCtx;
|
14073
14239
|
execute;
|
14074
|
-
|
14075
|
-
|
14240
|
+
options;
|
14241
|
+
createData;
|
14242
|
+
constructor(docCtx, renderCtx, execute) {
|
14243
|
+
this.docCtx = docCtx;
|
14076
14244
|
this.renderCtx = renderCtx;
|
14077
14245
|
this.execute = execute;
|
14246
|
+
this.options = this.docCtx.viewOptions;
|
14078
14247
|
this.execute = execute;
|
14248
|
+
this.createData = {
|
14249
|
+
options: this.options,
|
14250
|
+
renderCtx: this.renderCtx,
|
14251
|
+
execute: this.execute,
|
14252
|
+
onNextView: (cb) => { docCtx.onNextView(cb); }
|
14253
|
+
};
|
14079
14254
|
}
|
14080
14255
|
/**
|
14081
14256
|
* 段落排版:
|
@@ -14318,7 +14493,7 @@ class ParagraphMeasure {
|
|
14318
14493
|
}
|
14319
14494
|
}
|
14320
14495
|
arrangeInlineGroupElement(parentLine, ele) {
|
14321
|
-
const
|
14496
|
+
const createData = this.createData;
|
14322
14497
|
let render = this.createRenderObject(ele);
|
14323
14498
|
//记录多行情况下的渲染对象,用于计算总长度,生成fill-null-space
|
14324
14499
|
const inlineGroupRenders = [];
|
@@ -14359,7 +14534,7 @@ class ParagraphMeasure {
|
|
14359
14534
|
render.rect.width += space;
|
14360
14535
|
}
|
14361
14536
|
parentLine.applyNewLine();
|
14362
|
-
render = ele.createRenderObject(
|
14537
|
+
render = ele.createRenderObject(createData);
|
14363
14538
|
parentLine.add(render);
|
14364
14539
|
inlineGroupRenders.push(render);
|
14365
14540
|
},
|
@@ -14645,6 +14820,10 @@ class ParagraphMeasure {
|
|
14645
14820
|
const refCtx = execute.getObject(dep);
|
14646
14821
|
if (refCtx.ref) {
|
14647
14822
|
const refEle = refCtx.ref.item;
|
14823
|
+
//自己不能引用自己,避免死循环
|
14824
|
+
if (refEle === ele) {
|
14825
|
+
return;
|
14826
|
+
}
|
14648
14827
|
depEleMap.set(dep, refCtx);
|
14649
14828
|
//当前有可能是checkbox数组
|
14650
14829
|
const refEles = Array.isArray(refEle) ? refEle : [refEle];
|
@@ -14663,6 +14842,62 @@ class ParagraphMeasure {
|
|
14663
14842
|
console.error('解析表达式出错', ele.attribute?.visibleExpr);
|
14664
14843
|
}
|
14665
14844
|
}
|
14845
|
+
// /**
|
14846
|
+
// * 解析侦听表达式
|
14847
|
+
// * 当依赖性元素发生变化时,重新计算运行当前元素的表达式
|
14848
|
+
// * @param ele
|
14849
|
+
// * @param execute
|
14850
|
+
// * @private
|
14851
|
+
// */
|
14852
|
+
// parseEffectExpression(ele: Element, execute: DynamicExecute): void {
|
14853
|
+
// if (ele.effectExpr) return;
|
14854
|
+
// if (!ele.attribute?.effectExpr) return;
|
14855
|
+
// const reactiveMode = this.renderCtx.drawMode !== 'print';
|
14856
|
+
// try {
|
14857
|
+
// const depIdItems: Array<string> = [];
|
14858
|
+
// const depEleMap: Map<string, RefCtxValue> = new Map();
|
14859
|
+
// let compliedCode = parser(ele.attribute?.effectExpr, depIdItems);
|
14860
|
+
// compliedCode = addReturn(compliedCode);
|
14861
|
+
// ele.effectExpr = { compliedCode, func: new Function(`with(this){ ${compliedCode} }`), depItems: depEleMap };
|
14862
|
+
// if (depIdItems.length) {
|
14863
|
+
// depIdItems.forEach(dep => {
|
14864
|
+
// const refCtx = execute.getObject(dep);
|
14865
|
+
// if (refCtx.ref) {
|
14866
|
+
// const refEle = refCtx.ref.item as Element;
|
14867
|
+
// //自己不能引用自己,避免死循环
|
14868
|
+
// if (refEle === ele) {
|
14869
|
+
// return;
|
14870
|
+
// }
|
14871
|
+
// depEleMap.set(dep, refCtx);
|
14872
|
+
// //当前有可能是checkbox数组
|
14873
|
+
// const refEles = Array.isArray(refEle) ? refEle : [refEle];
|
14874
|
+
// reactiveMode && refEles.forEach(item => {
|
14875
|
+
// //求值依赖元素更改的时候,发布当前元素重新计算的指令
|
14876
|
+
// item.onChangeSubject.subscribe(() => {
|
14877
|
+
// try {
|
14878
|
+
// this.docCtx.onNextView(() => {
|
14879
|
+
// //当前元素可能被删除
|
14880
|
+
// const func = ele?.effectExpr?.func;
|
14881
|
+
// if (!func) {
|
14882
|
+
// return;
|
14883
|
+
// }
|
14884
|
+
// const tempExecuter = execute.create();
|
14885
|
+
// tempExecuter.setCurrentCtx(ele, ele.effectExpr.depItems);
|
14886
|
+
// const fn = func.bind(tempExecuter);
|
14887
|
+
// fn();
|
14888
|
+
// })
|
14889
|
+
// } catch (e) {
|
14890
|
+
// console.error(e, "表达式执行出错", ele.effectExpr.compliedCode);
|
14891
|
+
// }
|
14892
|
+
// });
|
14893
|
+
// });
|
14894
|
+
// }
|
14895
|
+
// });
|
14896
|
+
// }
|
14897
|
+
// } catch (e) {
|
14898
|
+
// console.error('解析表达式出错', ele.attribute?.effectExpr);
|
14899
|
+
// }
|
14900
|
+
// }
|
14666
14901
|
/**
|
14667
14902
|
* 元素可见行求值
|
14668
14903
|
* @param ele
|
@@ -14692,11 +14927,10 @@ class ParagraphMeasure {
|
|
14692
14927
|
return null;
|
14693
14928
|
}
|
14694
14929
|
}
|
14695
|
-
|
14696
|
-
|
14697
|
-
|
14698
|
-
|
14699
|
-
});
|
14930
|
+
// if (this.options.enableDyExpression) {
|
14931
|
+
// this.parseEffectExpression(element, this.execute);
|
14932
|
+
// }
|
14933
|
+
return element.createRenderObject(this.createData);
|
14700
14934
|
}
|
14701
14935
|
}
|
14702
14936
|
|
@@ -14710,6 +14944,8 @@ class SelectionOverlays {
|
|
14710
14944
|
selectionEleSets = new Map();
|
14711
14945
|
//批注对象集合
|
14712
14946
|
commRangeSets = new Map();
|
14947
|
+
//其他对象集合,例如查找对象
|
14948
|
+
otherRangeSets = new Map();
|
14713
14949
|
constructor(selectionState) {
|
14714
14950
|
this.selectionState = selectionState;
|
14715
14951
|
}
|
@@ -14759,6 +14995,18 @@ class SelectionOverlays {
|
|
14759
14995
|
this.addToSets(range.selectedChildren[i], set);
|
14760
14996
|
}
|
14761
14997
|
}
|
14998
|
+
addToOtherRangeSets(range) {
|
14999
|
+
if (!this.otherRangeSets.has(range.target)) {
|
15000
|
+
this.otherRangeSets.set(range.target, []);
|
15001
|
+
}
|
15002
|
+
this.otherRangeSets.get(range.target)?.push(range);
|
15003
|
+
for (let i = 0; i < range.selectedChildren.length; i++) {
|
15004
|
+
this.addToOtherRangeSets(range.selectedChildren[i]);
|
15005
|
+
}
|
15006
|
+
}
|
15007
|
+
clearOtherRangeSets() {
|
15008
|
+
this.otherRangeSets.clear();
|
15009
|
+
}
|
14762
15010
|
/**
|
14763
15011
|
* 添加到批注集合
|
14764
15012
|
* @param range
|
@@ -14851,7 +15099,7 @@ class DocumentArrange {
|
|
14851
15099
|
return suppressTracking(() => {
|
14852
15100
|
const doc = this.docCtx.document;
|
14853
15101
|
this.execute = new DynamicExecute(doc, this.docCtx.selectionState);
|
14854
|
-
this.pMeasure = new ParagraphMeasure(this.
|
15102
|
+
this.pMeasure = new ParagraphMeasure(this.docCtx, this.renderCtx, this.execute);
|
14855
15103
|
const data = {
|
14856
15104
|
doc,
|
14857
15105
|
options: this.options,
|
@@ -15059,7 +15307,7 @@ class DocumentArrange {
|
|
15059
15307
|
if (this.options.textRowLineMode && ele instanceof TableElement && ele.cacheRender) {
|
15060
15308
|
const cacheRender = ele.cacheRender;
|
15061
15309
|
clearChildrenRenderCache(ele);
|
15062
|
-
textLineRenderMode(cacheRender, { options: this.options, renderCtx: this.renderCtx, execute: this.execute });
|
15310
|
+
textLineRenderMode(cacheRender, { options: this.options, renderCtx: this.renderCtx, execute: this.execute, onNextView: (cb) => { this.docCtx.onNextView(cb); } });
|
15063
15311
|
}
|
15064
15312
|
}
|
15065
15313
|
getDocInnerRect(documentRender) {
|
@@ -15412,6 +15660,9 @@ class DocumentArrange {
|
|
15412
15660
|
clearPaintCache(ele, data) {
|
15413
15661
|
ele.paintRenders.length = 0;
|
15414
15662
|
ele.beginMeasure(data);
|
15663
|
+
if (ele.modifyFlag !== exports.ModifyFlag.None) {
|
15664
|
+
ele.onChangeSubject.next();
|
15665
|
+
}
|
15415
15666
|
this.identifyComment(ele);
|
15416
15667
|
if (ele instanceof BranchElement) {
|
15417
15668
|
for (let i = 0; i < ele.length; i++) {
|
@@ -15483,7 +15734,7 @@ class DocumentArrange {
|
|
15483
15734
|
if (!this.options.enableFastMeasure) {
|
15484
15735
|
return false;
|
15485
15736
|
}
|
15486
|
-
this.pMeasure = new ParagraphMeasure(this.
|
15737
|
+
this.pMeasure = new ParagraphMeasure(this.docCtx, this.renderCtx, this.execute);
|
15487
15738
|
const ops = this.docCtx.currentOpsLog;
|
15488
15739
|
if (!ops.length) {
|
15489
15740
|
return false;
|
@@ -15542,7 +15793,7 @@ class DocumentArrange {
|
|
15542
15793
|
return suppressTracking(() => {
|
15543
15794
|
const doc = this.docCtx.document;
|
15544
15795
|
this.execute = new DynamicExecute(doc, this.docCtx.selectionState);
|
15545
|
-
this.pMeasure = new ParagraphMeasure(this.
|
15796
|
+
this.pMeasure = new ParagraphMeasure(this.docCtx, this.renderCtx, this.execute);
|
15546
15797
|
const data = {
|
15547
15798
|
doc,
|
15548
15799
|
options: this.options,
|
@@ -15580,6 +15831,7 @@ class DocumentPaginator {
|
|
15580
15831
|
return;
|
15581
15832
|
}
|
15582
15833
|
this.docContainer = new DocumentContainerRender();
|
15834
|
+
//this.docContainer.padding.top = this.viewOptions.showRule ? 50 : 0;
|
15583
15835
|
this.docCtx.selectionState.renderContainer = this.docContainer;
|
15584
15836
|
this.docContainer.rect.width = this.viewOptions.docPageSettings.width;
|
15585
15837
|
const newMeasure = new DocumentArrange(this.docCtx, this.renderContext, this.seo);
|
@@ -16900,13 +17152,14 @@ class DocumentEvent {
|
|
16900
17152
|
moveCursorToLeftHandle(startControl, startOffset) {
|
16901
17153
|
if (startOffset === 0) {
|
16902
17154
|
const oldRegion = ElementUtil.getElementRegion(startControl);
|
16903
|
-
const
|
16904
|
-
if (
|
16905
|
-
const
|
17155
|
+
const cursorPosition = ElementUtil.getRecursionPrevSiblingElement(startControl, this.viewOptions);
|
17156
|
+
if (cursorPosition) {
|
17157
|
+
const { ele: prevEle, offset } = cursorPosition;
|
17158
|
+
const newRegion = ElementUtil.getElementRegion(cursorPosition.ele);
|
16906
17159
|
if (newRegion !== oldRegion) {
|
16907
17160
|
return;
|
16908
17161
|
}
|
16909
|
-
if (this.viewOptions.docMode === exports.DocMode.FormEdit && !ElementUtil.canSetCursor(prevEle,
|
17162
|
+
if (this.viewOptions.docMode === exports.DocMode.FormEdit && !ElementUtil.canSetCursor(prevEle, offset, true, this.viewOptions)) {
|
16910
17163
|
this.moveCursorToLeftHandle(prevEle, 0);
|
16911
17164
|
return;
|
16912
17165
|
}
|
@@ -16954,17 +17207,18 @@ class DocumentEvent {
|
|
16954
17207
|
moveCursorToRightHandle(startControl, startOffset) {
|
16955
17208
|
if (this.isLeafEleEndOffset(startControl, startOffset)) {
|
16956
17209
|
const oldRegion = ElementUtil.getElementRegion(startControl);
|
16957
|
-
const
|
16958
|
-
if (
|
16959
|
-
const
|
17210
|
+
const cursorPosition = ElementUtil.getRecursionNextSiblingElement(startControl, this.viewOptions);
|
17211
|
+
if (cursorPosition) {
|
17212
|
+
const { ele, offset } = cursorPosition;
|
17213
|
+
const newRegion = ElementUtil.getElementRegion(ele);
|
16960
17214
|
if (oldRegion !== newRegion) {
|
16961
17215
|
return;
|
16962
17216
|
}
|
16963
|
-
if (this.viewOptions.docMode === exports.DocMode.FormEdit && !ElementUtil.canSetCursor(
|
16964
|
-
this.moveCursorToRightHandle(
|
17217
|
+
if (this.viewOptions.docMode === exports.DocMode.FormEdit && !ElementUtil.canSetCursor(ele, offset, true, this.viewOptions)) {
|
17218
|
+
this.moveCursorToRightHandle(ele, offset);
|
16965
17219
|
return;
|
16966
17220
|
}
|
16967
|
-
this.selectionState.resetRange(
|
17221
|
+
this.selectionState.resetRange(ele, 0);
|
16968
17222
|
return;
|
16969
17223
|
}
|
16970
17224
|
}
|
@@ -17693,7 +17947,7 @@ class DocumentChange {
|
|
17693
17947
|
}
|
17694
17948
|
this.selectionState.clear();
|
17695
17949
|
//用于刷新后定位光标
|
17696
|
-
let startPointElement;
|
17950
|
+
let startPointElement = null;
|
17697
17951
|
let startPointOffset = 0;
|
17698
17952
|
if (selectedRange.isFullSelected) {
|
17699
17953
|
//某个容器的内容被全部选中
|
@@ -17743,8 +17997,14 @@ class DocumentChange {
|
|
17743
17997
|
startPointOffset = res.offset;
|
17744
17998
|
}
|
17745
17999
|
else {
|
17746
|
-
|
17747
|
-
|
18000
|
+
const cursorPosition = ElementUtil.getRecursionPrevSiblingElement(startRange.target, this.viewOptions);
|
18001
|
+
if (cursorPosition) {
|
18002
|
+
startPointElement = cursorPosition.ele;
|
18003
|
+
startPointOffset = cursorPosition.offset;
|
18004
|
+
}
|
18005
|
+
else {
|
18006
|
+
startPointElement = null;
|
18007
|
+
}
|
17748
18008
|
//判断结束选区和开始选区是否在一个段落中,尽量落在同一段落中
|
17749
18009
|
if (!startPointElement || ElementUtil.isInSameParagraph(startRange.target, endRange.target)) {
|
17750
18010
|
if (!endRange.isFullSelected) {
|
@@ -17801,11 +18061,12 @@ class DocumentChange {
|
|
17801
18061
|
onBackspaceElement(control, offset) {
|
17802
18062
|
this.selectionState.clear();
|
17803
18063
|
if (offset === 0) {
|
17804
|
-
const
|
17805
|
-
if (!
|
18064
|
+
const cursorPosition = ElementUtil.getRecursionPrevSiblingElement(control, this.viewOptions);
|
18065
|
+
if (!cursorPosition) {
|
17806
18066
|
this.selectionState.resetRange(control, 0);
|
17807
18067
|
return;
|
17808
18068
|
}
|
18069
|
+
const { ele: prevEle, offset } = cursorPosition;
|
17809
18070
|
if (ElementUtil.isInSameParagraph(control, prevEle)) {
|
17810
18071
|
if (ElementUtil.getPrevSiblingElement(control) === prevEle) {
|
17811
18072
|
this.onBackspaceElement(prevEle, ElementUtil.getElementEndOffset(prevEle));
|
@@ -17891,18 +18152,24 @@ class DocumentChange {
|
|
17891
18152
|
*/
|
17892
18153
|
onKeyDeleteElement(control, offset) {
|
17893
18154
|
this.selectionState.clear();
|
18155
|
+
if (control instanceof PSymbolElement) {
|
18156
|
+
offset = 1;
|
18157
|
+
}
|
17894
18158
|
if (offset === ElementUtil.getElementEndOffset(control)) {
|
17895
|
-
const
|
17896
|
-
if (!
|
18159
|
+
const cursorPosition = ElementUtil.getRecursionNextSiblingElement(control, this.viewOptions);
|
18160
|
+
if (!cursorPosition) {
|
17897
18161
|
this.selectionState.resetRange(control, -1);
|
17898
18162
|
return;
|
17899
18163
|
}
|
18164
|
+
//const {ele: nextEle, offset} = cursorPosition;
|
18165
|
+
const nextEle = cursorPosition.ele;
|
18166
|
+
offset = cursorPosition.offset;
|
17900
18167
|
if (ElementUtil.isInSameParagraph(control, nextEle)) {
|
17901
18168
|
if (ElementUtil.getNextSiblingElement(control) === nextEle) {
|
17902
|
-
this.onKeyDeleteElement(nextEle,
|
18169
|
+
this.onKeyDeleteElement(nextEle, offset);
|
17903
18170
|
}
|
17904
18171
|
else {
|
17905
|
-
this.selectionState.resetRange(nextEle,
|
18172
|
+
this.selectionState.resetRange(nextEle, offset);
|
17906
18173
|
}
|
17907
18174
|
}
|
17908
18175
|
else {
|
@@ -17915,7 +18182,7 @@ class DocumentChange {
|
|
17915
18182
|
this.selectionState.resetRange(nextEle, 0);
|
17916
18183
|
return;
|
17917
18184
|
}
|
17918
|
-
this.combineParagraph(
|
18185
|
+
this.combineParagraph(currPara, nextPara, control);
|
17919
18186
|
}
|
17920
18187
|
else {
|
17921
18188
|
//不是紧挨着的段落,则前一个段落是位于另一个容器里,例如:处于单元格内的段落
|
@@ -17935,21 +18202,29 @@ class DocumentChange {
|
|
17935
18202
|
}
|
17936
18203
|
}
|
17937
18204
|
else {
|
17938
|
-
|
18205
|
+
//当前为数据修饰元素,需要做额外判定是否需要删除数据元素
|
18206
|
+
if (ElementUtil.isDataEle(control.parent) && control instanceof DataDecorateElement) {
|
17939
18207
|
const dataEle = control.parent;
|
17940
18208
|
//空数据元,并且当前光标处于数据元开始位置
|
17941
|
-
if (
|
18209
|
+
if (dataEle.length === 2) {
|
17942
18210
|
if (this.canDeleteInlineGroup(dataEle)) {
|
17943
18211
|
this.setCursorForDeleteAction(dataEle);
|
17944
18212
|
dataEle.remove();
|
17945
18213
|
}
|
17946
18214
|
else {
|
17947
|
-
this.selectionState.resetRange(
|
18215
|
+
this.selectionState.resetRange(dataEle.startDecorate, 1);
|
17948
18216
|
}
|
17949
18217
|
return;
|
17950
18218
|
}
|
17951
|
-
else
|
17952
|
-
this.
|
18219
|
+
else {
|
18220
|
+
//this.setCursorForDeleteAction(dataEle);
|
18221
|
+
const cursorInfo = ElementUtil.getRecursionNextSiblingElement(control, this.viewOptions);
|
18222
|
+
if (cursorInfo) {
|
18223
|
+
this.selectionState.resetRange(cursorInfo.ele, cursorInfo.offset);
|
18224
|
+
}
|
18225
|
+
else {
|
18226
|
+
this.selectionState.resetRange(control, 0);
|
18227
|
+
}
|
17953
18228
|
return;
|
17954
18229
|
}
|
17955
18230
|
}
|
@@ -18021,14 +18296,14 @@ class DocumentChange {
|
|
18021
18296
|
//当前用户增加的内容,内容直接删除不需要留痕
|
18022
18297
|
if (this.isInCurrentUserTrack(target, exports.TrackRunTypeEnum.Inserted)) {
|
18023
18298
|
target.remove();
|
18024
|
-
this.
|
18299
|
+
this.removeEmptyInlineBlock(parent);
|
18025
18300
|
return;
|
18026
18301
|
}
|
18027
18302
|
//target.remove();
|
18028
18303
|
const trackEle = this.getNextTrackElement(target, exports.TrackRunTypeEnum.Deleted);
|
18029
18304
|
trackEle.addChild(target.clone(true), 0);
|
18030
18305
|
target.remove();
|
18031
|
-
this.
|
18306
|
+
this.removeEmptyInlineBlock(parent);
|
18032
18307
|
}
|
18033
18308
|
/**
|
18034
18309
|
* 更新文本删除留痕
|
@@ -18100,35 +18375,36 @@ class DocumentChange {
|
|
18100
18375
|
* @returns
|
18101
18376
|
*/
|
18102
18377
|
removeElement(control) {
|
18103
|
-
|
18104
|
-
if (!
|
18105
|
-
|
18106
|
-
if (
|
18378
|
+
let cursorPosition = ElementUtil.getRecursionPrevSiblingElement(control, this.viewOptions);
|
18379
|
+
if (!cursorPosition) {
|
18380
|
+
cursorPosition = ElementUtil.getRecursionNextSiblingElement(control, this.viewOptions);
|
18381
|
+
if (cursorPosition) {
|
18107
18382
|
//this.selectionState.resetRange(nextEle, 0);
|
18108
|
-
this.setSelectionStateByDeleteEvent(
|
18383
|
+
this.setSelectionStateByDeleteEvent(cursorPosition.ele, cursorPosition.offset, control);
|
18109
18384
|
control.remove();
|
18110
18385
|
return;
|
18111
18386
|
}
|
18112
18387
|
this.selectionState.resetRange(control, 0);
|
18113
18388
|
return;
|
18114
18389
|
}
|
18115
|
-
if (ElementUtil.isInSameParagraph(control,
|
18390
|
+
if (ElementUtil.isInSameParagraph(control, cursorPosition.ele)) {
|
18116
18391
|
//this.selectionState.resetRange(prevEle, -1);
|
18117
|
-
this.setSelectionStateByDeleteEvent(
|
18392
|
+
this.setSelectionStateByDeleteEvent(cursorPosition.ele, -1, control);
|
18118
18393
|
control.remove();
|
18119
18394
|
return;
|
18120
18395
|
}
|
18121
18396
|
else {
|
18122
|
-
const
|
18123
|
-
if (
|
18397
|
+
const cursorPosition = ElementUtil.getRecursionNextSiblingElement(control, this.viewOptions);
|
18398
|
+
if (cursorPosition && ElementUtil.getPrevSiblingElement(cursorPosition.ele) === control) {
|
18124
18399
|
//this.selectionState.resetRange(nextEle, 0);
|
18125
|
-
this.setSelectionStateByDeleteEvent(
|
18400
|
+
this.setSelectionStateByDeleteEvent(cursorPosition.ele, cursorPosition.offset, control);
|
18126
18401
|
control.remove();
|
18127
18402
|
return;
|
18128
18403
|
}
|
18129
18404
|
else {
|
18130
18405
|
//this.selectionState.resetRange(prevEle, -1);
|
18131
|
-
this.setSelectionStateByDeleteEvent(
|
18406
|
+
//this.setSelectionStateByDeleteEvent(cursorPosition.ele, -1, control);
|
18407
|
+
//TODO: 需要检测下
|
18132
18408
|
control.remove();
|
18133
18409
|
return;
|
18134
18410
|
}
|
@@ -18647,7 +18923,7 @@ class DocumentChange {
|
|
18647
18923
|
}
|
18648
18924
|
//表单模式:如果复制的是单格式的文本,需要序列化为纯文本处理
|
18649
18925
|
if (this.viewOptions.docMode === exports.DocMode.FormEdit) {
|
18650
|
-
const pasteString = pasteEles.map(item => ElementSerialize.serializeString(item
|
18926
|
+
const pasteString = pasteEles.map(item => ElementSerialize.serializeString(item)).join('');
|
18651
18927
|
if (pasteString) {
|
18652
18928
|
this.pastePlainText(pasteString);
|
18653
18929
|
}
|
@@ -18884,7 +19160,10 @@ class DocumentChange {
|
|
18884
19160
|
}
|
18885
19161
|
validate() {
|
18886
19162
|
const dataEleList = this.docCtx.document.treeFilter(item => item instanceof DataElementInlineGroup);
|
18887
|
-
const errorEleList = dataEleList.map(item => ({
|
19163
|
+
const errorEleList = dataEleList.map(item => ({
|
19164
|
+
error: item.validate(),
|
19165
|
+
ele: item
|
19166
|
+
})).filter(item => item.error);
|
18888
19167
|
if (!errorEleList.length) {
|
18889
19168
|
return true;
|
18890
19169
|
}
|
@@ -18918,7 +19197,7 @@ class DocumentChange {
|
|
18918
19197
|
this.setCursorForDeleteAction(text);
|
18919
19198
|
const parent = text.parent;
|
18920
19199
|
text.remove();
|
18921
|
-
this.
|
19200
|
+
this.removeEmptyInlineBlock(parent);
|
18922
19201
|
}
|
18923
19202
|
setCursorForDeleteAction(control) {
|
18924
19203
|
const cursorInfo = this.getCursorElementByDeleteAction(control);
|
@@ -18936,12 +19215,9 @@ class DocumentChange {
|
|
18936
19215
|
return ele.parent instanceof DataElementInlineGroup || ele.parent instanceof DataElementGroupElement;
|
18937
19216
|
};
|
18938
19217
|
if (isInDataAre(control)) {
|
18939
|
-
const
|
18940
|
-
if (
|
18941
|
-
return
|
18942
|
-
ele: prevLeafElementInPara,
|
18943
|
-
offset: ElementUtil.getElementEndOffset(prevLeafElementInPara)
|
18944
|
-
};
|
19218
|
+
const cursorPosition = ElementUtil.getRecursionPrevSiblingElement(control, this.viewOptions);
|
19219
|
+
if (cursorPosition && isInDataAre(cursorPosition.ele)) {
|
19220
|
+
return cursorPosition;
|
18945
19221
|
}
|
18946
19222
|
else {
|
18947
19223
|
return {
|
@@ -18951,27 +19227,21 @@ class DocumentChange {
|
|
18951
19227
|
}
|
18952
19228
|
}
|
18953
19229
|
}
|
18954
|
-
const
|
19230
|
+
const cursorPosition = ElementUtil.getRecursionPrevSiblingElement(control, this.viewOptions);
|
18955
19231
|
//是否为同一段落
|
18956
|
-
if (
|
18957
|
-
return
|
18958
|
-
ele: prevLeafElementInPara,
|
18959
|
-
offset: ElementUtil.getElementEndOffset(prevLeafElementInPara)
|
18960
|
-
};
|
19232
|
+
if (cursorPosition && ElementUtil.isInSameParagraph(cursorPosition.ele, control)) {
|
19233
|
+
return cursorPosition;
|
18961
19234
|
}
|
18962
19235
|
//同一段落其他元素
|
18963
|
-
const
|
18964
|
-
if (
|
18965
|
-
return
|
18966
|
-
ele: nextLeafElementInPara,
|
18967
|
-
offset: 0
|
18968
|
-
};
|
19236
|
+
const nextCursorPosition = ElementUtil.getRecursionNextSiblingElement(control, this.viewOptions);
|
19237
|
+
if (nextCursorPosition) {
|
19238
|
+
return nextCursorPosition;
|
18969
19239
|
}
|
18970
19240
|
//上一段落
|
18971
|
-
if (
|
19241
|
+
if (cursorPosition) {
|
18972
19242
|
return {
|
18973
|
-
ele:
|
18974
|
-
offset:
|
19243
|
+
ele: cursorPosition.ele,
|
19244
|
+
offset: cursorPosition.ele instanceof PSymbolElement ? 0 : ElementUtil.getElementEndOffset(cursorPosition.ele)
|
18975
19245
|
};
|
18976
19246
|
}
|
18977
19247
|
return null;
|
@@ -18980,11 +19250,12 @@ class DocumentChange {
|
|
18980
19250
|
* 移除空行内标签
|
18981
19251
|
* @param ele
|
18982
19252
|
*/
|
18983
|
-
|
19253
|
+
removeEmptyInlineBlock(ele) {
|
18984
19254
|
if (ele instanceof InlineGroupElement && ele.length === 0) {
|
18985
19255
|
const parent = ele.parent;
|
18986
19256
|
ele.remove();
|
18987
|
-
|
19257
|
+
//track-run 标签等
|
19258
|
+
this.removeEmptyInlineBlock(parent);
|
18988
19259
|
}
|
18989
19260
|
}
|
18990
19261
|
/**
|
@@ -19798,6 +20069,12 @@ class DocumentSvg {
|
|
19798
20069
|
const range = this.sso.commRangeSets.get(render.element);
|
19799
20070
|
createMaskVNode(range, selectionMask.mask);
|
19800
20071
|
}
|
20072
|
+
if (this.sso.otherRangeSets.has(render.element)) {
|
20073
|
+
const ranges = this.sso.otherRangeSets.get(render.element);
|
20074
|
+
ranges.forEach(range => {
|
20075
|
+
createMaskVNode(range, selectionMask.mask);
|
20076
|
+
});
|
20077
|
+
}
|
19801
20078
|
}
|
19802
20079
|
getHTMLVNode(docRenders) {
|
19803
20080
|
this.counterMap = {};
|
@@ -20004,6 +20281,7 @@ class EditorCalendarVNode {
|
|
20004
20281
|
if (parent) {
|
20005
20282
|
const parentRect = parent.getBoundingClientRect();
|
20006
20283
|
const elmRect = elm.getBoundingClientRect();
|
20284
|
+
const top = parseInt(elm.style.top);
|
20007
20285
|
// elmRect.width /= scale;
|
20008
20286
|
// elmRect.height /= scale;
|
20009
20287
|
// parentRect.width /= scale;
|
@@ -20019,12 +20297,13 @@ class EditorCalendarVNode {
|
|
20019
20297
|
//elm.style.left = parentRect.width - elmRect.width + 'px';
|
20020
20298
|
}
|
20021
20299
|
if (elmRect.top + elmRect.height > parentRect.top + parentRect.height) {
|
20022
|
-
const newTop =
|
20023
|
-
|
20300
|
+
const newTop = top - 5 - position.height - elmRect.height;
|
20301
|
+
position.y + 5 + position.height;
|
20024
20302
|
//计算前后的高度的差距,然后判断新的值是否在父元素的范围内,如果不在则使用旧的值
|
20025
|
-
if (newTop > 0 && oldTop - newTop < elmRect.top - parentRect.top) {
|
20026
|
-
|
20027
|
-
}
|
20303
|
+
// if (newTop > 0 && oldTop - newTop < elmRect.top - parentRect.top) {
|
20304
|
+
// elm.style.top = (position.y - position.height - elmRect.height) + 'px';
|
20305
|
+
// }
|
20306
|
+
elm.style.top = newTop + 'px';
|
20028
20307
|
//elm.style.top = (top - (elmRect.top + elmRect.height - (parentRect.top + parentRect.height))) + 'px';
|
20029
20308
|
//elm.style.top = (position.y - position.height - elmRect.height) + 'px';
|
20030
20309
|
}
|
@@ -20104,7 +20383,7 @@ class EditorCalendarVNode {
|
|
20104
20383
|
const sel = 'div.editor-calendar-body-day-item'
|
20105
20384
|
+ (day.isCurrentMonth ? ".editor-calendar-body-day-item--current-month" : "")
|
20106
20385
|
+ (day.today ? ".editor-calendar-body-day-item--today" : "")
|
20107
|
-
+ (this.selectedDate.value === day.date ? ".editor-calendar-
|
20386
|
+
+ (this.selectedDate.value === day.date ? ".editor-calendar-item--selected" : "");
|
20108
20387
|
return {
|
20109
20388
|
sel,
|
20110
20389
|
data: {
|
@@ -20439,21 +20718,23 @@ class EditorCalendarVNode {
|
|
20439
20718
|
}
|
20440
20719
|
}
|
20441
20720
|
|
20721
|
+
const svgNS = "http://www.w3.org/2000/svg";
|
20442
20722
|
class DocRule {
|
20443
20723
|
docCtx;
|
20444
20724
|
//private ctx!: CanvasRenderingContext2D;
|
20445
20725
|
options;
|
20446
20726
|
//标尺高度
|
20447
|
-
ruleHeight =
|
20727
|
+
ruleHeight = 28;
|
20728
|
+
thumbWidth = 12;
|
20448
20729
|
//当前标尺的位置
|
20449
20730
|
thumbX;
|
20450
20731
|
mouseDownPos;
|
20451
|
-
indentThumbPoints = [];
|
20452
|
-
hangThumbPoints = [];
|
20732
|
+
//private indentThumbPoints: Array<Position> = [];
|
20733
|
+
//private hangThumbPoints: Array<Position> = [];
|
20453
20734
|
mouseDownThumbType = 'none';
|
20454
20735
|
viewOptions;
|
20455
20736
|
ss;
|
20456
|
-
nodes = [];
|
20737
|
+
//private nodes: Array<any> = [];
|
20457
20738
|
constructor(docCtx) {
|
20458
20739
|
this.docCtx = docCtx;
|
20459
20740
|
this.viewOptions = this.docCtx.viewOptions;
|
@@ -20469,14 +20750,8 @@ class DocRule {
|
|
20469
20750
|
indent: 0,
|
20470
20751
|
hanging: 0
|
20471
20752
|
};
|
20472
|
-
// this.canvas.addEventListener("mousedown", (evt) => this.canvasMousedown(evt));
|
20473
|
-
// this.canvas.addEventListener("mousemove", (evt) => this.canvasMousemove(evt));
|
20474
|
-
// this.canvas.addEventListener("mouseup", (evt) => this.canvasMouseup(evt));
|
20475
20753
|
}
|
20476
20754
|
destroy() {
|
20477
|
-
// this.canvas.removeEventListener("mousedown", this.canvasMousedown);
|
20478
|
-
// this.canvas.removeEventListener("mousemove", this.canvasMousemove);
|
20479
|
-
// this.canvas.removeEventListener("mouseup", this.canvasMouseup);
|
20480
20755
|
}
|
20481
20756
|
setRuleOptions(options) {
|
20482
20757
|
this.options = options;
|
@@ -20487,208 +20762,91 @@ class DocRule {
|
|
20487
20762
|
//ElementUtil.setCanvasProps(this.canvas, this.ctx, {width: this.getParentWidth(), height: this.ruleHeight});
|
20488
20763
|
//this.canvas.style.left = this.options.docLeft + 'px';
|
20489
20764
|
}
|
20490
|
-
fillRectSvg(x, y, width, height, color) {
|
20491
|
-
return ElementUtil.getFillSvgRect(x, y, width, height, color);
|
20492
|
-
}
|
20493
|
-
drawIndentThumbSvg(x, y) {
|
20494
|
-
const points = [];
|
20495
|
-
x -= 4;
|
20496
|
-
points.push({ x: x, y });
|
20497
|
-
points.push({ x: x, y: y + 3 });
|
20498
|
-
points.push({ x: x + 4, y: y + 7 });
|
20499
|
-
points.push({ x: x + 8, y: y + 3 });
|
20500
|
-
points.push({ x: x + 8, y });
|
20501
|
-
points.push({ x: x, y });
|
20502
|
-
this.drawLineSvg(points);
|
20503
|
-
return points;
|
20504
|
-
}
|
20505
|
-
drawHangThumbSvg(x, y) {
|
20506
|
-
const points = [];
|
20507
|
-
x -= 4;
|
20508
|
-
points.push({ x: x, y });
|
20509
|
-
points.push({ x: x, y: y - 3 });
|
20510
|
-
points.push({ x: x + 4, y: y - 7 });
|
20511
|
-
points.push({ x: x + 8, y: y - 3 });
|
20512
|
-
points.push({ x: x + 8, y });
|
20513
|
-
points.push({ x: x, y });
|
20514
|
-
points.push({ x: x, y: y + 3 });
|
20515
|
-
points.push({ x: x + 8, y: y + 3 });
|
20516
|
-
points.push({ x: x + 8, y: y });
|
20517
|
-
this.drawLineSvg(points);
|
20518
|
-
return points;
|
20519
|
-
}
|
20520
|
-
drawLineSvg(points) {
|
20521
|
-
this.nodes.push(ElementUtil.getStrokeSvgPath(points, "black", 0.5));
|
20522
|
-
}
|
20523
|
-
drawTextSvg(text, x, y) {
|
20524
|
-
this.nodes.push({
|
20525
|
-
sel: 'text',
|
20526
|
-
text: text,
|
20527
|
-
data: {
|
20528
|
-
ns: "http://www.w3.org/2000/svg",
|
20529
|
-
attrs: {
|
20530
|
-
'dominant-baseline': 'hanging',
|
20531
|
-
'font-family': "仿宋",
|
20532
|
-
'font-size': 8,
|
20533
|
-
x,
|
20534
|
-
y,
|
20535
|
-
'text-anchor': 'middle'
|
20536
|
-
}
|
20537
|
-
}
|
20538
|
-
});
|
20539
|
-
}
|
20540
20765
|
refreshRuleSvg() {
|
20541
20766
|
const editor = this;
|
20542
20767
|
return {
|
20543
20768
|
render() {
|
20544
|
-
|
20545
|
-
return null;
|
20546
|
-
}
|
20547
|
-
editor.nodes = [];
|
20548
|
-
editor.drawRuleSvg();
|
20549
|
-
const node = {
|
20550
|
-
sel: 'g', data: {
|
20551
|
-
ns: 'http://www.w3.org/2000/svg',
|
20552
|
-
}, children: [...editor.nodes]
|
20553
|
-
};
|
20554
|
-
return {
|
20555
|
-
sel: 'div.doc-rule',
|
20556
|
-
data: {
|
20557
|
-
style: {
|
20558
|
-
left: `${editor.options.docLeft}px`,
|
20559
|
-
},
|
20560
|
-
on: {
|
20561
|
-
mousedown: (evt) => editor.canvasMousedown(evt),
|
20562
|
-
mousemove: (evt) => editor.canvasMousemove(evt),
|
20563
|
-
mouseup: (evt) => editor.canvasMouseup(evt)
|
20564
|
-
}
|
20565
|
-
},
|
20566
|
-
children: [
|
20567
|
-
{
|
20568
|
-
sel: 'svg',
|
20569
|
-
data: {
|
20570
|
-
ns: 'http://www.w3.org/2000/svg',
|
20571
|
-
attrs: {
|
20572
|
-
width: editor.options.width,
|
20573
|
-
height: editor.ruleHeight
|
20574
|
-
}
|
20575
|
-
},
|
20576
|
-
children: [node]
|
20577
|
-
}
|
20578
|
-
]
|
20579
|
-
};
|
20769
|
+
return editor.getRuleSVG();
|
20580
20770
|
}
|
20581
20771
|
};
|
20582
20772
|
}
|
20583
|
-
|
20584
|
-
|
20585
|
-
|
20586
|
-
this.mouseDownThumbType = 'indent';
|
20587
|
-
this.mouseDownPos = clickPos;
|
20588
|
-
}
|
20589
|
-
else if (this.pointInPoly(clickPos, this.hangThumbPoints)) {
|
20590
|
-
this.mouseDownThumbType = 'hang';
|
20591
|
-
this.mouseDownPos = clickPos;
|
20592
|
-
}
|
20593
|
-
else {
|
20594
|
-
console.log("未点击在里面");
|
20773
|
+
getRuleSVG() {
|
20774
|
+
if (!this.viewOptions.showRule) {
|
20775
|
+
return null;
|
20595
20776
|
}
|
20596
|
-
|
20597
|
-
|
20598
|
-
|
20599
|
-
|
20600
|
-
|
20777
|
+
//editor.nodes = [];
|
20778
|
+
const paraRender = this.getRuleMarksPos();
|
20779
|
+
//editor.drawRuleSvg();
|
20780
|
+
const leftBg = ElementUtil.getFillSvgRect(0, 0, this.options.pagePL, this.ruleHeight, "rgb(198,198,198)");
|
20781
|
+
const rightBg = ElementUtil.getFillSvgRect(this.options.width - this.options.pagePR, 0, this.options.pagePR, this.ruleHeight, "rgb(198,198,198)");
|
20782
|
+
const svg = {
|
20783
|
+
sel: 'svg',
|
20784
|
+
data: {
|
20785
|
+
ns: svgNS,
|
20786
|
+
attrs: {
|
20787
|
+
width: this.options.width,
|
20788
|
+
height: this.ruleHeight
|
20789
|
+
}
|
20790
|
+
},
|
20791
|
+
children: [leftBg, rightBg]
|
20601
20792
|
};
|
20602
|
-
}
|
20603
|
-
canvasMousemove(evt) {
|
20604
|
-
if (['indent', 'hang'].indexOf(this.mouseDownThumbType) < 0) {
|
20605
|
-
return;
|
20606
|
-
}
|
20607
|
-
if (!this.mouseDownPos) {
|
20608
|
-
return;
|
20609
|
-
}
|
20610
|
-
const canvasPos = this.getMousePos(evt);
|
20611
|
-
let moveX = canvasPos.x - this.mouseDownPos.x;
|
20612
|
-
//至少移动5px再进行修改
|
20613
|
-
const remainder = moveX % 5;
|
20614
|
-
if (Math.abs(remainder) < 3) {
|
20615
|
-
return;
|
20616
|
-
}
|
20617
|
-
else {
|
20618
|
-
if (remainder < 0) {
|
20619
|
-
moveX -= 5 + remainder;
|
20620
|
-
}
|
20621
|
-
else {
|
20622
|
-
moveX += 5 - remainder;
|
20623
|
-
}
|
20624
|
-
}
|
20625
|
-
if (moveX === 0) {
|
20626
|
-
return;
|
20627
|
-
}
|
20628
|
-
canvasPos.x = this.mouseDownPos.x + moveX;
|
20629
|
-
const para = this.getCurrPara();
|
20630
|
-
if (!para) {
|
20631
|
-
throw new Error('para is null');
|
20632
|
-
}
|
20633
|
-
if (this.mouseDownThumbType === 'indent') {
|
20634
|
-
this.thumbX.indent += moveX;
|
20635
|
-
this.thumbX.indent = this.thumbX.indent < 0 ? 0 : this.thumbX.indent;
|
20636
|
-
this.thumbX.indent = this.thumbX.indent > this.options.width ? this.options.width : this.thumbX.indent;
|
20637
|
-
this.mouseDownPos = canvasPos;
|
20638
|
-
para.props.indent += moveX;
|
20639
|
-
this.drawRuleSvg();
|
20640
|
-
}
|
20641
|
-
if (this.mouseDownThumbType === 'hang') {
|
20642
|
-
this.thumbX.hanging += moveX;
|
20643
|
-
this.thumbX.hanging = this.thumbX.hanging < 0 ? 0 : this.thumbX.hanging;
|
20644
|
-
this.thumbX.hanging = this.thumbX.hanging > this.options.width ? this.options.width : this.thumbX.hanging;
|
20645
|
-
this.mouseDownPos = canvasPos;
|
20646
|
-
para.props.hanging += moveX;
|
20647
|
-
this.drawRuleSvg();
|
20648
|
-
}
|
20649
|
-
}
|
20650
|
-
canvasMouseup(evt) {
|
20651
|
-
this.mouseDownThumbType = 'none';
|
20652
|
-
this.mouseDownPos = null;
|
20653
|
-
}
|
20654
|
-
pointInPoly(pt, poly) {
|
20655
|
-
let c = false;
|
20656
|
-
for (let i = -1, l = poly.length, j = l - 1; ++i < l; j = i) {
|
20657
|
-
if (((poly[i].y <= pt.y && pt.y < poly[j].y) || (poly[j].y <= pt.y && pt.y < poly[i].y)) && pt.x < ((poly[j].x - poly[i].x) * (pt.y - poly[i].y)) / (poly[j].y - poly[i].y) + poly[i].x) {
|
20658
|
-
c = !c;
|
20659
|
-
}
|
20660
|
-
}
|
20661
|
-
return c;
|
20662
|
-
}
|
20663
|
-
/**
|
20664
|
-
* 绘制
|
20665
|
-
*/
|
20666
|
-
drawRuleSvg() {
|
20667
|
-
this.getRuleMarksPos();
|
20668
|
-
this.nodes.push(ElementUtil.getFillSvgRect(0, 0, this.options.pagePL, this.ruleHeight, "rgb(198,198,198)"));
|
20669
|
-
this.nodes.push(ElementUtil.getFillSvgRect(this.options.width - this.options.pagePR, 0, this.options.pagePR, this.ruleHeight, "rgb(198,198,198)"));
|
20670
20793
|
for (let j = 0; j < 50; j++) {
|
20671
|
-
const gantWidth =
|
20672
|
-
const points = [];
|
20794
|
+
const gantWidth = 38;
|
20795
|
+
//const points: Array<Position> = [];
|
20673
20796
|
const x = j * gantWidth;
|
20674
20797
|
if (x > this.options.width) {
|
20675
20798
|
break;
|
20676
20799
|
}
|
20677
20800
|
const y = 10;
|
20678
|
-
|
20679
|
-
|
20680
|
-
|
20801
|
+
svg.children.push(ElementUtil.getStrokeSvgPath([{ x, y }, { x, y: y + 10 }], "black", 0.5));
|
20802
|
+
svg.children.push({
|
20803
|
+
sel: 'text',
|
20804
|
+
text: j,
|
20805
|
+
data: {
|
20806
|
+
ns: svgNS,
|
20807
|
+
attrs: {
|
20808
|
+
'dominant-baseline': 'hanging',
|
20809
|
+
'font-family': "仿宋",
|
20810
|
+
'font-size': 10,
|
20811
|
+
x: x + Math.floor(gantWidth / 2),
|
20812
|
+
y,
|
20813
|
+
'text-anchor': 'middle'
|
20814
|
+
}
|
20815
|
+
}
|
20816
|
+
});
|
20681
20817
|
}
|
20682
|
-
|
20683
|
-
|
20684
|
-
|
20818
|
+
const indentThumb = this.createTopThumb();
|
20819
|
+
const hangThumb = this.createLeftThumb();
|
20820
|
+
this.drawCellMark(svg.children, paraRender);
|
20821
|
+
return {
|
20822
|
+
sel: 'div.rule-wrapper',
|
20823
|
+
data: {
|
20824
|
+
style: {
|
20825
|
+
transform: 'scale(' + this.viewOptions.scale + ')',
|
20826
|
+
'transform-origin': '0 0'
|
20827
|
+
}
|
20828
|
+
},
|
20829
|
+
children: [{
|
20830
|
+
sel: 'div.doc-rule',
|
20831
|
+
data: {
|
20832
|
+
style: {
|
20833
|
+
left: `${this.options.docLeft}px`,
|
20834
|
+
}
|
20835
|
+
},
|
20836
|
+
children: [
|
20837
|
+
svg,
|
20838
|
+
indentThumb,
|
20839
|
+
hangThumb
|
20840
|
+
]
|
20841
|
+
}]
|
20842
|
+
};
|
20685
20843
|
}
|
20686
20844
|
getRuleMarksPos() {
|
20687
20845
|
const { startControl, startOffset, startHitInfo } = this.ss;
|
20688
20846
|
if (!startControl || !startHitInfo) {
|
20689
20847
|
this.thumbX.indent = 0;
|
20690
20848
|
this.thumbX.hanging = 0;
|
20691
|
-
return;
|
20849
|
+
return null;
|
20692
20850
|
}
|
20693
20851
|
const para = ElementUtil.getParentByType(startControl, ParagraphElement);
|
20694
20852
|
const indent = para.props.indent;
|
@@ -20706,7 +20864,8 @@ class DocRule {
|
|
20706
20864
|
this.thumbX.indent = paraRenderPos.x - docRenderPos.x + indent;
|
20707
20865
|
this.thumbX.hanging = paraRenderPos.x - docRenderPos.x + hanging;
|
20708
20866
|
this.options.docLeft = docRender.rect.x + docRender.parent.rect.x;
|
20709
|
-
|
20867
|
+
return paraRender;
|
20868
|
+
//this.setParentMarksPosSvg(paraRender);
|
20710
20869
|
}
|
20711
20870
|
getCurrPara() {
|
20712
20871
|
const { startControl, startOffset } = this.ss;
|
@@ -20715,32 +20874,172 @@ class DocRule {
|
|
20715
20874
|
}
|
20716
20875
|
return ElementUtil.getParentByType(startControl, ParagraphElement);
|
20717
20876
|
}
|
20718
|
-
|
20719
|
-
|
20720
|
-
|
20721
|
-
if (!parentRender || parentRender instanceof DocumentRenderObject) {
|
20722
|
-
return items;
|
20877
|
+
drawCellMark(svgChildren, parentRender) {
|
20878
|
+
if (!parentRender) {
|
20879
|
+
return;
|
20723
20880
|
}
|
20724
|
-
|
20725
|
-
|
20726
|
-
|
20727
|
-
|
20728
|
-
|
20729
|
-
|
20730
|
-
|
20731
|
-
|
20881
|
+
const tableRowRender = ElementUtil.getParentRender(parentRender, TableRowRenderObject);
|
20882
|
+
if (!tableRowRender) {
|
20883
|
+
return;
|
20884
|
+
}
|
20885
|
+
const docRender = ElementUtil.getParentRender(parentRender, DocumentRenderObject);
|
20886
|
+
const docRenderPos = ElementUtil.getRenderAbsolutePaintPos(docRender);
|
20887
|
+
for (let i = 0; i < tableRowRender.length; i++) {
|
20888
|
+
const cellRender = tableRowRender.getChild(i);
|
20889
|
+
const pos = ElementUtil.getRenderAbsolutePaintPos(cellRender);
|
20890
|
+
svgChildren.push(ElementUtil.getFillSvgRect(pos.x - docRenderPos.x - 1, 0, 2, this.ruleHeight, "#bbb"));
|
20732
20891
|
}
|
20733
|
-
items.push(...this.setParentMarksPosSvg(parentRender));
|
20734
|
-
return items;
|
20735
20892
|
}
|
20736
|
-
|
20737
|
-
|
20738
|
-
|
20739
|
-
|
20740
|
-
|
20741
|
-
|
20893
|
+
/**
|
20894
|
+
* 绘制首行缩进thumb
|
20895
|
+
* @returns
|
20896
|
+
*/
|
20897
|
+
createTopThumb() {
|
20898
|
+
const para = this.getCurrPara();
|
20899
|
+
if (!para) {
|
20900
|
+
return null;
|
20742
20901
|
}
|
20902
|
+
const onMousedown = (evt) => {
|
20903
|
+
evt.preventDefault();
|
20904
|
+
//const pos = this.getMousePos(evt);
|
20905
|
+
const oldX = evt.x;
|
20906
|
+
const para = this.getCurrPara();
|
20907
|
+
if (!para) {
|
20908
|
+
return;
|
20909
|
+
}
|
20910
|
+
const indent = para.props.indent;
|
20911
|
+
const mousemoveHandler = (e) => {
|
20912
|
+
//const pos = this.getMousePos(e);
|
20913
|
+
let x = e.x - oldX; // 计算相对于SVG的X坐标
|
20914
|
+
x /= this.viewOptions.scale;
|
20915
|
+
let snappedX = Math.round(x / 5) * 5; // 捕捉到最近的5像素倍数
|
20916
|
+
if (indent + snappedX >= 0) {
|
20917
|
+
para.props.indent = indent + snappedX;
|
20918
|
+
}
|
20919
|
+
};
|
20920
|
+
const mouseupHandler = () => {
|
20921
|
+
document.removeEventListener('mouseup', mouseupHandler);
|
20922
|
+
document.removeEventListener('mousemove', mousemoveHandler);
|
20923
|
+
};
|
20924
|
+
document.addEventListener('mousemove', mousemoveHandler);
|
20925
|
+
document.addEventListener('mouseup', mouseupHandler);
|
20926
|
+
};
|
20927
|
+
const svg = {
|
20928
|
+
sel: "svg",
|
20929
|
+
data: {
|
20930
|
+
ns: svgNS,
|
20931
|
+
attrs: {
|
20932
|
+
width: 12,
|
20933
|
+
height: 12,
|
20934
|
+
viewBox: "0 0 16 16",
|
20935
|
+
fill: "none",
|
20936
|
+
"stroke-width": 1.5,
|
20937
|
+
},
|
20938
|
+
},
|
20939
|
+
children: [
|
20940
|
+
{
|
20941
|
+
sel: "g#group-1",
|
20942
|
+
data: { ns: svgNS, attrs: { stroke: "white", fill: "white" } },
|
20943
|
+
children: [
|
20944
|
+
{
|
20945
|
+
sel: "path",
|
20946
|
+
data: { ns: svgNS, attrs: { d: "M14.25 3.75V7.37868C14.25 7.7765 14.092 8.15804 13.8107 8.43934L8.70711 13.5429C8.31658 13.9334 7.68342 13.9334 7.29289 13.5429L2.18934 8.43934C1.90804 8.15804 1.75 7.7765 1.75 7.37868V3.75C1.75 2.64543 2.64543 1.75 3.75 1.75H12.25C13.3546 1.75 14.25 2.64543 14.25 3.75Z", stroke: "none" } },
|
20947
|
+
},
|
20948
|
+
],
|
20949
|
+
},
|
20950
|
+
{
|
20951
|
+
sel: "g#group-0",
|
20952
|
+
data: { ns: svgNS, attrs: { stroke: "#757575", fill: "#757575" } },
|
20953
|
+
children: [
|
20954
|
+
{
|
20955
|
+
sel: "path",
|
20956
|
+
data: { ns: svgNS, attrs: { d: "M14.25 3.75V7.37868C14.25 7.7765 14.092 8.15804 13.8107 8.43934L8.70711 13.5429C8.31658 13.9334 7.68342 13.9334 7.29289 13.5429L2.18934 8.43934C1.90804 8.15804 1.75 7.7765 1.75 7.37868V3.75C1.75 2.64543 2.64543 1.75 3.75 1.75H12.25C13.3546 1.75 14.25 2.64543 14.25 3.75Z", fill: "none", "vector-effect": "non-scaling-stroke" } },
|
20957
|
+
},
|
20958
|
+
],
|
20959
|
+
},
|
20960
|
+
],
|
20961
|
+
};
|
20962
|
+
return { sel: "div.rule-thumb-container.rule-thumb-top", data: { on: { mousedown: (evt) => { onMousedown(evt); } }, style: { left: this.thumbX.indent - this.thumbWidth / 2 + "px" } }, children: [{ sel: "i.icon-thumb", data: {}, children: [svg] }] };
|
20743
20963
|
}
|
20964
|
+
;
|
20965
|
+
/**
|
20966
|
+
* 绘制悬挂缩进thumb
|
20967
|
+
* @returns
|
20968
|
+
*/
|
20969
|
+
createLeftThumb() {
|
20970
|
+
const para = this.getCurrPara();
|
20971
|
+
if (!para) {
|
20972
|
+
return null;
|
20973
|
+
}
|
20974
|
+
const onMousedown = (evt) => {
|
20975
|
+
evt.preventDefault();
|
20976
|
+
const oldX = evt.x;
|
20977
|
+
const para = this.getCurrPara();
|
20978
|
+
if (!para) {
|
20979
|
+
return;
|
20980
|
+
}
|
20981
|
+
const hanging = para.props.hanging;
|
20982
|
+
const mousemoveHandler = (e) => {
|
20983
|
+
let x = e.x - oldX; // 计算相对于SVG的X坐标
|
20984
|
+
x /= this.viewOptions.scale;
|
20985
|
+
let snappedX = Math.round(x / 5) * 5; // 捕捉到最近的5像素倍数
|
20986
|
+
if (hanging + snappedX >= 0) {
|
20987
|
+
para.props.hanging = hanging + snappedX;
|
20988
|
+
}
|
20989
|
+
};
|
20990
|
+
const mouseupHandler = () => {
|
20991
|
+
document.removeEventListener('mouseup', mouseupHandler);
|
20992
|
+
document.removeEventListener('mousemove', mousemoveHandler);
|
20993
|
+
};
|
20994
|
+
document.addEventListener('mousemove', mousemoveHandler);
|
20995
|
+
document.addEventListener('mouseup', mouseupHandler);
|
20996
|
+
};
|
20997
|
+
const svg = {
|
20998
|
+
sel: "svg",
|
20999
|
+
data: {
|
21000
|
+
ns: svgNS,
|
21001
|
+
attrs: {
|
21002
|
+
width: 12,
|
21003
|
+
height: 12,
|
21004
|
+
viewBox: "0 0 16 16",
|
21005
|
+
fill: "none",
|
21006
|
+
"stroke-width": 1.5,
|
21007
|
+
},
|
21008
|
+
},
|
21009
|
+
children: [
|
21010
|
+
{
|
21011
|
+
sel: "g#group-1",
|
21012
|
+
data: { ns: svgNS, attrs: { stroke: "white", fill: "white" } },
|
21013
|
+
children: [
|
21014
|
+
{
|
21015
|
+
sel: "path",
|
21016
|
+
data: { ns: svgNS, attrs: { d: "M14.25 12.25V8.62132C14.25 8.2235 14.092 7.84196 13.8107 7.56066L8.70711 2.45711C8.31658 2.06658 7.68342 2.06658 7.29289 2.45711L2.18934 7.56066C1.90804 7.84196 1.75 8.2235 1.75 8.62132V12.25C1.75 13.3546 2.64543 14.25 3.75 14.25H12.25C13.3546 14.25 14.25 13.3546 14.25 12.25Z", stroke: "none" } },
|
21017
|
+
},
|
21018
|
+
],
|
21019
|
+
},
|
21020
|
+
{
|
21021
|
+
sel: "g#group-0",
|
21022
|
+
data: { ns: svgNS, attrs: { stroke: "#757575", fill: "#757575" } },
|
21023
|
+
children: [
|
21024
|
+
{
|
21025
|
+
sel: "path",
|
21026
|
+
data: { ns: svgNS, attrs: { d: "M7.11612 2.11612L2.29917 6.93306C1.94754 7.28469 1.75 7.7616 1.75 8.25888V12.2469C1.75 13.3515 2.64543 14.2469 3.75 14.2469C6.58333 14.2469 9.41667 14.2469 12.25 14.2469C13.3546 14.2469 14.25 13.3515 14.25 12.2469V8.25888C14.25 7.7616 14.0525 7.28469 13.7008 6.93306L8.88388 2.11612M7.11612 2.11612C7.60427 1.62796 8.39573 1.62796 8.88388 2.11612M7.11612 2.11612L2.16901 7.06323C1.90072 7.33151 1.75 7.69538 1.75 8.0748C1.75 9.12824 2.60399 9.98223 3.65744 9.98223H12.3426C13.396 9.98223 14.25 9.12824 14.25 8.0748C14.25 7.69538 14.0993 7.33151 13.831 7.06323L8.88388 2.11612", fill: "none", "vector-effect": "non-scaling-stroke" } },
|
21027
|
+
},
|
21028
|
+
],
|
21029
|
+
},
|
21030
|
+
],
|
21031
|
+
};
|
21032
|
+
return {
|
21033
|
+
sel: "div.rule-thumb-container.rule-thumb-left",
|
21034
|
+
data: {
|
21035
|
+
on: {
|
21036
|
+
mousedown: (evt) => { onMousedown(evt); }
|
21037
|
+
}, style: { left: this.thumbX.hanging - this.thumbWidth / 2 + 'px' }
|
21038
|
+
},
|
21039
|
+
children: [{ sel: "i.icon-thumb", data: {}, children: [svg] }],
|
21040
|
+
};
|
21041
|
+
}
|
21042
|
+
;
|
20744
21043
|
}
|
20745
21044
|
|
20746
21045
|
function calculateOverflow(rect, viewport) {
|
@@ -20891,6 +21190,250 @@ function calculateDistance(a, b) {
|
|
20891
21190
|
return Math.sqrt(deltaX * deltaX + deltaY * deltaY);
|
20892
21191
|
}
|
20893
21192
|
|
21193
|
+
class SearchPanel {
|
21194
|
+
editor;
|
21195
|
+
searchQuery = '';
|
21196
|
+
currentIndex = -1;
|
21197
|
+
totalMatches = 0;
|
21198
|
+
searchResults = [];
|
21199
|
+
searchRangeColor = "#ffffb8";
|
21200
|
+
currentRangeColor = "#fadb14";
|
21201
|
+
inputRef;
|
21202
|
+
state = 'close';
|
21203
|
+
constructor(editor) {
|
21204
|
+
this.editor = editor;
|
21205
|
+
}
|
21206
|
+
render() {
|
21207
|
+
if (this.state === 'close') {
|
21208
|
+
return null;
|
21209
|
+
}
|
21210
|
+
return snabbdom.h('div.editor-search-box', [
|
21211
|
+
snabbdom.h('input.search-input', {
|
21212
|
+
props: {
|
21213
|
+
placeholder: 'Search'
|
21214
|
+
},
|
21215
|
+
on: {
|
21216
|
+
keydown: (evt) => this.onKeydown(evt)
|
21217
|
+
},
|
21218
|
+
hook: {
|
21219
|
+
insert: (vNode) => {
|
21220
|
+
this.inputRef = vNode.elm;
|
21221
|
+
}
|
21222
|
+
}
|
21223
|
+
}),
|
21224
|
+
snabbdom.h('span.search-count', `${this.currentIndex + 1} of ${this.totalMatches}`),
|
21225
|
+
snabbdom.h('button.icon-button', {
|
21226
|
+
on: {
|
21227
|
+
click: () => this.searchPrevious()
|
21228
|
+
}
|
21229
|
+
}, [
|
21230
|
+
snabbdom.h('span.material-icons', [
|
21231
|
+
snabbdom.h('svg', {
|
21232
|
+
attrs: {
|
21233
|
+
width: '18',
|
21234
|
+
height: '18',
|
21235
|
+
viewBox: '0 0 24 24',
|
21236
|
+
fill: 'none',
|
21237
|
+
xmlns: 'http://www.w3.org/2000/svg'
|
21238
|
+
}
|
21239
|
+
}, [
|
21240
|
+
snabbdom.h('path', {
|
21241
|
+
attrs: {
|
21242
|
+
d: 'M4.28377 10.2949C3.89615 10.6883 3.90084 11.3215 4.29424 11.7091C4.68765 12.0967 5.3208 12.092 5.70842 11.6986L10.9998 6.32833V19.9994C10.9998 20.5517 11.4475 20.9994 11.9998 20.9994C12.552 20.9994 12.9998 20.5517 12.9998 19.9994V6.33481L18.2847 11.6986C18.6723 12.092 19.3055 12.0967 19.6989 11.7091C20.0923 11.3215 20.097 10.6883 19.7094 10.2949L12.887 3.37073C12.3974 2.87382 11.5958 2.87382 11.1062 3.37073L4.28377 10.2949Z',
|
21243
|
+
fill: '#212121'
|
21244
|
+
}
|
21245
|
+
})
|
21246
|
+
])
|
21247
|
+
])
|
21248
|
+
]),
|
21249
|
+
snabbdom.h('button.icon-button', {
|
21250
|
+
on: {
|
21251
|
+
click: () => this.searchNext()
|
21252
|
+
}
|
21253
|
+
}, [
|
21254
|
+
snabbdom.h('span.material-icons', [
|
21255
|
+
snabbdom.h('svg', {
|
21256
|
+
attrs: {
|
21257
|
+
width: '18',
|
21258
|
+
height: '18',
|
21259
|
+
viewBox: '0 0 24 24',
|
21260
|
+
fill: 'none',
|
21261
|
+
xmlns: 'http://www.w3.org/2000/svg'
|
21262
|
+
}
|
21263
|
+
}, [
|
21264
|
+
snabbdom.h('path', {
|
21265
|
+
attrs: {
|
21266
|
+
d: 'M19.7162 13.7045C20.1038 13.3111 20.0991 12.678 19.7057 12.2903C19.3123 11.9027 18.6792 11.9074 18.2915 12.3008L13.0002 17.6711V4C13.0002 3.44771 12.5525 3 12.0002 3C11.4479 3 11.0002 3.44772 11.0002 4V17.6646L5.71525 12.3008C5.32763 11.9074 4.69448 11.9027 4.30108 12.2903C3.90767 12.678 3.90298 13.3111 4.29061 13.7045L11.113 20.6287C11.6026 21.1256 12.4042 21.1256 12.8938 20.6287L19.7162 13.7045Z',
|
21267
|
+
fill: '#212121'
|
21268
|
+
}
|
21269
|
+
})
|
21270
|
+
])
|
21271
|
+
])
|
21272
|
+
]),
|
21273
|
+
snabbdom.h('button.icon-button', {
|
21274
|
+
on: {
|
21275
|
+
click: () => this.destroy()
|
21276
|
+
}
|
21277
|
+
}, [
|
21278
|
+
snabbdom.h('span.material-icons', [
|
21279
|
+
snabbdom.h('svg', {
|
21280
|
+
attrs: {
|
21281
|
+
width: '18',
|
21282
|
+
height: '18',
|
21283
|
+
viewBox: '0 0 24 24',
|
21284
|
+
fill: 'none',
|
21285
|
+
xmlns: 'http://www.w3.org/2000/svg'
|
21286
|
+
}
|
21287
|
+
}, [
|
21288
|
+
snabbdom.h('path', {
|
21289
|
+
attrs: {
|
21290
|
+
d: 'M4.2097 4.3871L4.29289 4.29289C4.65338 3.93241 5.22061 3.90468 5.6129 4.2097L5.70711 4.29289L12 10.585L18.2929 4.29289C18.6834 3.90237 19.3166 3.90237 19.7071 4.29289C20.0976 4.68342 20.0976 5.31658 19.7071 5.70711L13.415 12L19.7071 18.2929C20.0676 18.6534 20.0953 19.2206 19.7903 19.6129L19.7071 19.7071C19.3466 20.0676 18.7794 20.0953 18.3871 19.7903L18.2929 19.7071L12 13.415L5.70711 19.7071C5.31658 20.0976 4.68342 20.0976 4.29289 19.7071C3.90237 19.3166 3.90237 18.6834 4.29289 18.2929L10.585 12L4.29289 5.70711C3.93241 5.34662 3.90468 4.77939 4.2097 4.3871L4.29289 4.29289L4.2097 4.3871Z',
|
21291
|
+
fill: '#212121'
|
21292
|
+
}
|
21293
|
+
})
|
21294
|
+
])
|
21295
|
+
])
|
21296
|
+
])
|
21297
|
+
]);
|
21298
|
+
}
|
21299
|
+
searchNext() {
|
21300
|
+
const searchItem = this.searchResults[this.currentIndex];
|
21301
|
+
if (searchItem && searchItem.range) {
|
21302
|
+
searchItem.range.rangeColor = this.searchRangeColor;
|
21303
|
+
}
|
21304
|
+
if (this.totalMatches > 0) {
|
21305
|
+
this.currentIndex = this.currentIndex + 1;
|
21306
|
+
if (this.currentIndex === this.totalMatches) {
|
21307
|
+
this.currentIndex = 0;
|
21308
|
+
}
|
21309
|
+
this.nagivateToShow();
|
21310
|
+
}
|
21311
|
+
}
|
21312
|
+
;
|
21313
|
+
searchPrevious() {
|
21314
|
+
const searchItem = this.searchResults[this.currentIndex];
|
21315
|
+
if (searchItem && searchItem.range) {
|
21316
|
+
searchItem.range.rangeColor = this.searchRangeColor;
|
21317
|
+
}
|
21318
|
+
if (this.totalMatches > 0) {
|
21319
|
+
this.currentIndex = this.currentIndex - 1;
|
21320
|
+
if (this.currentIndex === -1) {
|
21321
|
+
this.currentIndex = this.totalMatches - 1;
|
21322
|
+
}
|
21323
|
+
this.nagivateToShow();
|
21324
|
+
}
|
21325
|
+
}
|
21326
|
+
;
|
21327
|
+
nagivateToShow() {
|
21328
|
+
Promise.resolve().then(() => {
|
21329
|
+
const searchItem = this.searchResults[this.currentIndex];
|
21330
|
+
const range = searchItem.range;
|
21331
|
+
//突出显示当前项颜色
|
21332
|
+
range["rangeColor"] = this.currentRangeColor;
|
21333
|
+
const editor = this.editor;
|
21334
|
+
editor.bringToView(searchItem.ele);
|
21335
|
+
editor.flushToSchedule();
|
21336
|
+
editor.docCtx.onNextView(() => {
|
21337
|
+
this.inputRef.focus();
|
21338
|
+
});
|
21339
|
+
});
|
21340
|
+
}
|
21341
|
+
onKeydown(e) {
|
21342
|
+
if (e.key === "Enter") {
|
21343
|
+
e.preventDefault();
|
21344
|
+
this.searchInDocument(e);
|
21345
|
+
}
|
21346
|
+
}
|
21347
|
+
;
|
21348
|
+
searchInDocument(e) {
|
21349
|
+
// 这里应该是你的搜索逻辑,返回匹配的结果数组
|
21350
|
+
const target = e.target;
|
21351
|
+
const query = target.value;
|
21352
|
+
if (!query) {
|
21353
|
+
//清除搜索结果
|
21354
|
+
this.clear();
|
21355
|
+
return [];
|
21356
|
+
}
|
21357
|
+
//回车自动转到下一个输入
|
21358
|
+
if (this.searchQuery === target.value) {
|
21359
|
+
this.searchNext();
|
21360
|
+
return;
|
21361
|
+
}
|
21362
|
+
this.clear();
|
21363
|
+
this.searchQuery = target.value;
|
21364
|
+
const overlays = this.editor['selectionOverlays'];
|
21365
|
+
const textEles = this.editor.docCtx.document.treeFilter((item) => item.type === "text");
|
21366
|
+
textEles.forEach((ele) => {
|
21367
|
+
const matches = this.findMatches(ele.text, query);
|
21368
|
+
matches.forEach((index) => {
|
21369
|
+
this.searchResults.push({
|
21370
|
+
index,
|
21371
|
+
ele,
|
21372
|
+
});
|
21373
|
+
});
|
21374
|
+
});
|
21375
|
+
console.log(this.searchResults);
|
21376
|
+
overlays.clearOtherRangeSets();
|
21377
|
+
this.searchResults.forEach((item) => {
|
21378
|
+
const range = {
|
21379
|
+
target: item.ele,
|
21380
|
+
isFullSelected: false,
|
21381
|
+
selectedChildren: [],
|
21382
|
+
startOffset: item.index,
|
21383
|
+
endOffset: item.index + query.length,
|
21384
|
+
rangeColor: this.searchRangeColor,
|
21385
|
+
};
|
21386
|
+
item.range = range;
|
21387
|
+
overlays.addToOtherRangeSets(range);
|
21388
|
+
});
|
21389
|
+
this.totalMatches = this.searchResults.length;
|
21390
|
+
this.currentIndex = -1;
|
21391
|
+
this.searchNext();
|
21392
|
+
this.editor.docCtx.onNextView(() => {
|
21393
|
+
target.focus();
|
21394
|
+
});
|
21395
|
+
//editor['selectionOverlays']
|
21396
|
+
return [];
|
21397
|
+
}
|
21398
|
+
clear() {
|
21399
|
+
this.searchQuery = "";
|
21400
|
+
this.searchResults.length = 0;
|
21401
|
+
this.currentIndex = -1;
|
21402
|
+
this.totalMatches = 0;
|
21403
|
+
}
|
21404
|
+
destroy() {
|
21405
|
+
this.clear();
|
21406
|
+
this.state = 'close';
|
21407
|
+
const overlays = this.editor["selectionOverlays"];
|
21408
|
+
overlays.clearOtherRangeSets();
|
21409
|
+
this.editor.flushToSchedule();
|
21410
|
+
}
|
21411
|
+
findMatches(inputString, pattern) {
|
21412
|
+
// 创建一个正则表达式对象
|
21413
|
+
const regex = new RegExp(pattern, "g");
|
21414
|
+
const matches = [];
|
21415
|
+
let match;
|
21416
|
+
// 使用正则表达式的exec方法多次搜索字符串以找到所有匹配项
|
21417
|
+
while ((match = regex.exec(inputString)) !== null) {
|
21418
|
+
matches.push(match.index); // 将匹配的索引位置添加到数组中
|
21419
|
+
// 当匹配的模式长度为0时(如匹配空字符串),避免无限循环
|
21420
|
+
if (match[0].length === 0) {
|
21421
|
+
regex.lastIndex++;
|
21422
|
+
}
|
21423
|
+
}
|
21424
|
+
return matches;
|
21425
|
+
}
|
21426
|
+
switchVisible() {
|
21427
|
+
if (this.state === 'open') {
|
21428
|
+
this.state = 'close';
|
21429
|
+
}
|
21430
|
+
else {
|
21431
|
+
this.state = 'open';
|
21432
|
+
}
|
21433
|
+
this.clear();
|
21434
|
+
}
|
21435
|
+
}
|
21436
|
+
|
20894
21437
|
class DocEditor {
|
20895
21438
|
svgContainer;
|
20896
21439
|
//设置vue 不允许代理
|
@@ -20939,15 +21482,17 @@ class DocEditor {
|
|
20939
21482
|
// private suggestions: Array<ISuggestionData> = [];
|
20940
21483
|
//光标keydown事件
|
20941
21484
|
onKeyDownEvent = new Subject();
|
21485
|
+
//搜索框
|
21486
|
+
searchPanel;
|
20942
21487
|
constructor(svgContainer) {
|
20943
21488
|
this.svgContainer = svgContainer;
|
20944
21489
|
this.createCanvasContext();
|
20945
21490
|
this.viewOptions = new ViewOptions();
|
20946
21491
|
this.documentSelection = new DocumentSelection();
|
20947
|
-
this.
|
21492
|
+
this.selectionState = this.documentSelection.selectionState;
|
21493
|
+
this.docCtx = new EditorContext(this.selectionState, this.viewOptions);
|
20948
21494
|
this.viewOptions.copyRightInfo = '电子病历编辑器(XXX版权所有)';
|
20949
21495
|
this.viewOptions.drawCharRectColor = 'green';
|
20950
|
-
this.viewOptions.showLineRect = true;
|
20951
21496
|
this.viewOptions.docSpace = 20;
|
20952
21497
|
this.viewOptions.defaultFontName = '宋体';
|
20953
21498
|
this.viewOptions.editorVersion = this.version();
|
@@ -20957,16 +21502,10 @@ class DocEditor {
|
|
20957
21502
|
width: 1000,
|
20958
21503
|
height: 200
|
20959
21504
|
};
|
20960
|
-
this.viewOptions.editUser = {
|
20961
|
-
id: '6666',
|
20962
|
-
name: '管理员'
|
20963
|
-
};
|
20964
|
-
this.viewOptions.fullPageView = false;
|
20965
21505
|
this.createDocViewer();
|
20966
21506
|
this.renderContext = new RenderContext(new PaintContent(this.contentCtx));
|
20967
21507
|
this.renderContext.init({ width: 2, height: 2, scale: 1 });
|
20968
|
-
this.
|
20969
|
-
this.selectionOverlays = new SelectionOverlays(this.documentSelection.selectionState);
|
21508
|
+
this.selectionOverlays = new SelectionOverlays(this.selectionState);
|
20970
21509
|
this.documentPaginator = new DocumentPaginator(this.renderContext, this.docCtx, this.selectionOverlays);
|
20971
21510
|
this.documentInput = new DocumentInput(this.docCtx);
|
20972
21511
|
this.docComment = new DocumentComment(this.docCtx);
|
@@ -20974,6 +21513,7 @@ class DocEditor {
|
|
20974
21513
|
this.documentChange = new DocumentChange(this.elementReader, this.docCtx, this.docComment, this.documentInput);
|
20975
21514
|
this.documentEvent = new DocumentEvent(this.documentPaginator, this.docCtx, this.documentInput);
|
20976
21515
|
this.historyMange = new ElementTrackManage(this.docCtx);
|
21516
|
+
this.searchPanel = new SearchPanel(this);
|
20977
21517
|
this.eventBus = new EventBus();
|
20978
21518
|
this.createPatch();
|
20979
21519
|
this.documentEvent.hitInfoChanged.subscribe((hitInfo) => {
|
@@ -21008,8 +21548,8 @@ class DocEditor {
|
|
21008
21548
|
this.docCtx.syncRefresh = () => {
|
21009
21549
|
this.flushToSchedule();
|
21010
21550
|
};
|
21011
|
-
this.viewOptions.onChange.subscribe((
|
21012
|
-
this.resetViewer(
|
21551
|
+
this.viewOptions.onChange.subscribe(() => {
|
21552
|
+
this.resetViewer();
|
21013
21553
|
});
|
21014
21554
|
}
|
21015
21555
|
createCanvasContext() {
|
@@ -21054,7 +21594,7 @@ class DocEditor {
|
|
21054
21594
|
};
|
21055
21595
|
const listVNode = this.renderDataListVNode();
|
21056
21596
|
const dropContainer = {
|
21057
|
-
sel: 'div.
|
21597
|
+
sel: 'div.absolute-container',
|
21058
21598
|
data: {
|
21059
21599
|
style: {
|
21060
21600
|
'transform-origin': '0 0',
|
@@ -21089,7 +21629,8 @@ class DocEditor {
|
|
21089
21629
|
style: {
|
21090
21630
|
overflow: 'auto',
|
21091
21631
|
position: 'relative',
|
21092
|
-
height: "100%"
|
21632
|
+
height: "100%",
|
21633
|
+
'transform-origin': '0 0'
|
21093
21634
|
},
|
21094
21635
|
on: {
|
21095
21636
|
scroll: (evt) => {
|
@@ -21111,8 +21652,9 @@ class DocEditor {
|
|
21111
21652
|
}
|
21112
21653
|
}
|
21113
21654
|
},
|
21114
|
-
children: [docContentVNode, dropContainer]
|
21115
|
-
},
|
21655
|
+
children: [docContentVNode, dropContainer,]
|
21656
|
+
},
|
21657
|
+
ruleFunc.refreshRuleSvg().render(), this.searchPanel.render()
|
21116
21658
|
]
|
21117
21659
|
};
|
21118
21660
|
}
|
@@ -21511,9 +22053,8 @@ class DocEditor {
|
|
21511
22053
|
};
|
21512
22054
|
this.onChange();
|
21513
22055
|
}
|
21514
|
-
resetViewer(
|
21515
|
-
|
21516
|
-
if (refreshType === 'content') {
|
22056
|
+
resetViewer() {
|
22057
|
+
if (this.docCtx.document) {
|
21517
22058
|
this.docCtx.document.pubOnChange('self');
|
21518
22059
|
}
|
21519
22060
|
this.documentPaginator.layoutPages();
|
@@ -21866,7 +22407,7 @@ class DocEditor {
|
|
21866
22407
|
setPaperOrient(orientation) {
|
21867
22408
|
this.docCtx.document.props.orient = orientation;
|
21868
22409
|
this.viewOptions.docPageSettings.orient = orientation;
|
21869
|
-
this.resetViewer(
|
22410
|
+
this.resetViewer();
|
21870
22411
|
this.selectionState.clear();
|
21871
22412
|
}
|
21872
22413
|
setPaperSize(width, height) {
|
@@ -21882,13 +22423,17 @@ class DocEditor {
|
|
21882
22423
|
width = Math.floor(width * this.viewOptions.mmToPixelsRatio);
|
21883
22424
|
height = Math.floor(height * this.viewOptions.mmToPixelsRatio);
|
21884
22425
|
this.viewOptions.docPageSettings = new PageOptions(width, height, docProps.orient);
|
21885
|
-
this.resetViewer(
|
22426
|
+
this.resetViewer();
|
21886
22427
|
}
|
21887
22428
|
/**
|
21888
22429
|
* 显示当前元素到视图中
|
21889
22430
|
* @param element
|
21890
22431
|
*/
|
21891
22432
|
bringToView(element) {
|
22433
|
+
//元素被删除
|
22434
|
+
if (!element.parent || !element.paintRenders.length) {
|
22435
|
+
return;
|
22436
|
+
}
|
21892
22437
|
const ele = element instanceof BranchElement ? ElementUtil.getFirstLeafElement(element) : element;
|
21893
22438
|
if (ele) {
|
21894
22439
|
const region = ElementUtil.getElementRegion(ele);
|
@@ -21906,10 +22451,16 @@ class DocEditor {
|
|
21906
22451
|
//处理缩放
|
21907
22452
|
pos.x = pos.x * scale;
|
21908
22453
|
pos.y = pos.y * scale;
|
21909
|
-
|
21910
|
-
|
22454
|
+
this.viewOptions.pageOffset.y;
|
22455
|
+
const scrollHeight = this.viewOptions.viewSettings.height;
|
22456
|
+
// 计算中心位置需要的scrollTop
|
22457
|
+
var newScrollTop = pos.y - scrollHeight / 2;
|
22458
|
+
// 检查newScrollTop是否小于0
|
22459
|
+
if (newScrollTop < 0) {
|
22460
|
+
newScrollTop = 0; // 保证滚动不会超出容器顶部
|
21911
22461
|
}
|
21912
|
-
|
22462
|
+
// 滚动到新的位置
|
22463
|
+
this.scrollContainer.scrollTop = newScrollTop;
|
21913
22464
|
}
|
21914
22465
|
/**
|
21915
22466
|
* 设置当前文档页边距
|
@@ -22350,6 +22901,7 @@ class DocEditor {
|
|
22350
22901
|
if (parent) {
|
22351
22902
|
const parentRect = parent.getBoundingClientRect();
|
22352
22903
|
const elmRect = elm.getBoundingClientRect();
|
22904
|
+
const top = parseInt(elm.style.top);
|
22353
22905
|
// elmRect.width /= scale;
|
22354
22906
|
// elmRect.height /= scale;
|
22355
22907
|
// parentRect.width /= scale;
|
@@ -22365,12 +22917,13 @@ class DocEditor {
|
|
22365
22917
|
//elm.style.left = parentRect.width - elmRect.width + 'px';
|
22366
22918
|
}
|
22367
22919
|
if (elmRect.top + elmRect.height > parentRect.top + parentRect.height) {
|
22368
|
-
const newTop =
|
22369
|
-
|
22920
|
+
const newTop = top - 5 - position.height - elmRect.height;
|
22921
|
+
position.y + 5 + position.height;
|
22370
22922
|
//计算前后的高度的差距,然后判断新的值是否在父元素的范围内,如果不在则使用旧的值
|
22371
|
-
if (newTop > 0 && oldTop - newTop < elmRect.top - parentRect.top) {
|
22372
|
-
|
22373
|
-
}
|
22923
|
+
// if (newTop > 0 && oldTop - newTop < elmRect.top - parentRect.top) {
|
22924
|
+
// elm.style.top = (position.y - position.height - elmRect.height) + 'px';
|
22925
|
+
// }
|
22926
|
+
elm.style.top = newTop + 'px';
|
22374
22927
|
//elm.style.top = (top - (elmRect.top + elmRect.height - (parentRect.top + parentRect.height))) + 'px';
|
22375
22928
|
//elm.style.top = (position.y - position.height - elmRect.height) + 'px';
|
22376
22929
|
}
|
@@ -22481,14 +23034,14 @@ class DocEditor {
|
|
22481
23034
|
rule.setRuleOptions({ width: this.viewOptions.docPageSettings.width, pagePL, pagePR, docLeft });
|
22482
23035
|
}
|
22483
23036
|
version() {
|
22484
|
-
return "2.2.
|
23037
|
+
return "2.2.22";
|
22485
23038
|
}
|
22486
23039
|
switchPageHeaderEditor() {
|
22487
23040
|
this.docCtx.document.switchPageHeaderEditor(this.selectionState, null);
|
22488
23041
|
}
|
22489
23042
|
getTextContent() {
|
22490
23043
|
const paras = this.docCtx.document.treeFilter(item => item instanceof ParagraphElement);
|
22491
|
-
const paraTexts = paras.map(item => ElementSerialize.serializeString(item
|
23044
|
+
const paraTexts = paras.map(item => ElementSerialize.serializeString(item));
|
22492
23045
|
return paraTexts.join('');
|
22493
23046
|
}
|
22494
23047
|
emit(event, args) {
|
@@ -22653,24 +23206,25 @@ class DocEditor {
|
|
22653
23206
|
}
|
22654
23207
|
processKeyDownEvent(evt) {
|
22655
23208
|
const keyEvent = new KeyboradElementEvent(this.docCtx);
|
23209
|
+
const keyStr = CommonUtil.getKeyCombination(evt);
|
22656
23210
|
keyEvent.sourceEvent = evt;
|
22657
23211
|
if (DocumentEvent.invokeEvent('ElementKeyDown', this.docCtx.selectionState.startControl, keyEvent, 'All')) {
|
22658
23212
|
evt.preventDefault();
|
22659
23213
|
return;
|
22660
23214
|
}
|
22661
|
-
if (
|
23215
|
+
if (['ArrowDown', 'ArrowUp']) {
|
22662
23216
|
if (this.docCtx.suggestions.prepareSuggestions.length) {
|
22663
23217
|
this.onSuggestionsKeydown(evt);
|
22664
23218
|
}
|
22665
23219
|
}
|
22666
|
-
else if (
|
23220
|
+
else if (keyStr === 'Escape') {
|
22667
23221
|
if (this.docCtx.suggestions.prepareSuggestions.length) {
|
22668
23222
|
evt.preventDefault();
|
22669
23223
|
this.docCtx.suggestions.clear();
|
22670
23224
|
this.onPatchVNodeSubject.next();
|
22671
23225
|
}
|
22672
23226
|
}
|
22673
|
-
else if (
|
23227
|
+
else if (keyStr === 'Enter') {
|
22674
23228
|
if (this.docCtx.suggestions.prepareSuggestions.length) {
|
22675
23229
|
evt.preventDefault();
|
22676
23230
|
const suggestions = this.docCtx.suggestions;
|
@@ -22686,6 +23240,11 @@ class DocEditor {
|
|
22686
23240
|
}
|
22687
23241
|
}
|
22688
23242
|
}
|
23243
|
+
else if (['Ctrl+f', 'Cmd+f'].indexOf(keyStr) > -1) {
|
23244
|
+
evt.preventDefault();
|
23245
|
+
this.searchPanel.switchVisible();
|
23246
|
+
this.onPatchVNodeSubject.next();
|
23247
|
+
}
|
22689
23248
|
}
|
22690
23249
|
/**
|
22691
23250
|
* 处理候选词,键盘选择定位
|
@@ -27987,9 +28546,7 @@ class DocumentPrintOffscreenBase {
|
|
27987
28546
|
constructor() {
|
27988
28547
|
this.viewOptions = new ViewOptions();
|
27989
28548
|
this.viewOptions.copyRightInfo = '';
|
27990
|
-
this.viewOptions.showCharRect = true;
|
27991
28549
|
this.viewOptions.drawCharRectColor = 'green';
|
27992
|
-
this.viewOptions.showLineRect = true;
|
27993
28550
|
this.viewOptions.docSpace = 20;
|
27994
28551
|
this.viewOptions.reviewWindowWidth = 200;
|
27995
28552
|
this.viewOptions.mmToPixelsRatio = 3.7795001220703126;
|
@@ -27998,17 +28555,14 @@ class DocumentPrintOffscreenBase {
|
|
27998
28555
|
width: 1000,
|
27999
28556
|
height: 800
|
28000
28557
|
};
|
28001
|
-
this.viewOptions.editUser = {
|
28002
|
-
id: '6666',
|
28003
|
-
name: '管理员'
|
28004
|
-
};
|
28005
28558
|
const { canvas, ctx } = this.createCanvas(200, 200);
|
28006
28559
|
const ss = new SelectionState();
|
28007
28560
|
this.docCtx = new EditorContext(ss, this.viewOptions);
|
28008
28561
|
this.renderCtx = this.createRenderCtx(ctx, this.viewOptions, this.docCtx);
|
28009
28562
|
this.documentPaginator = new DocumentPaginator(this.renderCtx, this.docCtx, {
|
28010
28563
|
selectionEleSets: new Map(),
|
28011
|
-
commRangeSets: new Map()
|
28564
|
+
commRangeSets: new Map(),
|
28565
|
+
otherRangeSets: new Map()
|
28012
28566
|
});
|
28013
28567
|
this.elementReader = new ElementReader(this.docCtx);
|
28014
28568
|
this.docCtx.syncRefresh = () => {
|
@@ -28076,7 +28630,8 @@ class DocumentPrintOffscreenBase {
|
|
28076
28630
|
getSvgNodes(docRenders, printRanges = null) {
|
28077
28631
|
const docSvgHelper = new DocumentSvg(this.viewOptions, {
|
28078
28632
|
selectionEleSets: new Map,
|
28079
|
-
commRangeSets: new Map()
|
28633
|
+
commRangeSets: new Map(),
|
28634
|
+
otherRangeSets: new Map()
|
28080
28635
|
}, this.renderCtx); //.getHTMLVNode(docRenders) as Array<EditorVNodeObject>;
|
28081
28636
|
docSvgHelper.mode = 'print';
|
28082
28637
|
const patch = init([
|
@@ -28148,11 +28703,11 @@ const deleteCurrentParagraph = (evt) => {
|
|
28148
28703
|
caption: '删除段落', click: () => {
|
28149
28704
|
selectionState.clear();
|
28150
28705
|
const psymbol = ElementUtil.getLastLeafElement(currentElement);
|
28151
|
-
const
|
28706
|
+
const cursorPosition = ElementUtil.getRecursionNextSiblingElement(psymbol, viewOptions);
|
28152
28707
|
const parentContainer = currentElement.parent;
|
28153
|
-
if (
|
28154
|
-
if (
|
28155
|
-
selectionState.resetRange(
|
28708
|
+
if (cursorPosition) {
|
28709
|
+
if (cursorPosition.ele.parent === parentContainer) {
|
28710
|
+
selectionState.resetRange(cursorPosition.ele, 0);
|
28156
28711
|
}
|
28157
28712
|
else {
|
28158
28713
|
selectionState.resetRange(parentContainer, 0);
|
@@ -28193,9 +28748,9 @@ const onTableContextmenu = (evt) => {
|
|
28193
28748
|
evt.menus.push({
|
28194
28749
|
caption: '删除表格', click: () => {
|
28195
28750
|
selectionState.clear();
|
28196
|
-
const
|
28197
|
-
if (
|
28198
|
-
selectionState.resetRange(
|
28751
|
+
const cursorPosition = ElementUtil.getRecursionPrevSiblingElement(currentElement, viewOptions);
|
28752
|
+
if (cursorPosition) {
|
28753
|
+
selectionState.resetRange(cursorPosition.ele, cursorPosition.offset);
|
28199
28754
|
}
|
28200
28755
|
currentElement.remove();
|
28201
28756
|
currentElement.destroy();
|