@hailin-zheng/editor-core 1.0.15 → 1.0.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/README.md +1613 -0
- package/lib/framework/element-props.d.ts +2 -2
- package/lib/framework/impl/index.d.ts +36 -0
- package/lib/index.d.ts +34 -0
- package/lib/index.js +15672 -0
- package/lib/texteditor.d.ts +3 -3
- package/package.json +27 -26
- package/lib/doc-ruler.js +0 -313
- package/lib/doc-ruler.js.map +0 -1
- package/lib/framework/common-util.js +0 -178
- package/lib/framework/common-util.js.map +0 -1
- package/lib/framework/document-change.js +0 -1342
- package/lib/framework/document-change.js.map +0 -1
- package/lib/framework/document-combine.js +0 -40
- package/lib/framework/document-combine.js.map +0 -1
- package/lib/framework/document-comment.js +0 -148
- package/lib/framework/document-comment.js.map +0 -1
- package/lib/framework/document-context.js +0 -330
- package/lib/framework/document-context.js.map +0 -1
- package/lib/framework/document-eval-func.js +0 -48
- package/lib/framework/document-eval-func.js.map +0 -1
- package/lib/framework/document-event.js +0 -1054
- package/lib/framework/document-event.js.map +0 -1
- package/lib/framework/document-history.js +0 -65
- package/lib/framework/document-history.js.map +0 -1
- package/lib/framework/document-images-loader.js +0 -66
- package/lib/framework/document-images-loader.js.map +0 -1
- package/lib/framework/document-input-cursor.js +0 -239
- package/lib/framework/document-input-cursor.js.map +0 -1
- package/lib/framework/document-paint.js +0 -103
- package/lib/framework/document-paint.js.map +0 -1
- package/lib/framework/document-print-offscreen.js +0 -128
- package/lib/framework/document-print-offscreen.js.map +0 -1
- package/lib/framework/document-print.js +0 -203
- package/lib/framework/document-print.js.map +0 -1
- package/lib/framework/document-segmenter.js +0 -106
- package/lib/framework/document-segmenter.js.map +0 -1
- package/lib/framework/document-selection.js +0 -358
- package/lib/framework/document-selection.js.map +0 -1
- package/lib/framework/document-template.js +0 -20
- package/lib/framework/document-template.js.map +0 -1
- package/lib/framework/document-textline-mode.js +0 -30
- package/lib/framework/document-textline-mode.js.map +0 -1
- package/lib/framework/element-define.js +0 -579
- package/lib/framework/element-define.js.map +0 -1
- package/lib/framework/element-event-define.js +0 -108
- package/lib/framework/element-event-define.js.map +0 -1
- package/lib/framework/element-measure.js +0 -551
- package/lib/framework/element-measure.js.map +0 -1
- package/lib/framework/element-paint.js +0 -170
- package/lib/framework/element-paint.js.map +0 -1
- package/lib/framework/element-props.js +0 -809
- package/lib/framework/element-props.js.map +0 -1
- package/lib/framework/element-reader.js +0 -151
- package/lib/framework/element-reader.js.map +0 -1
- package/lib/framework/element-render-cut.js +0 -449
- package/lib/framework/element-render-cut.js.map +0 -1
- package/lib/framework/element-serialize.js +0 -113
- package/lib/framework/element-serialize.js.map +0 -1
- package/lib/framework/element-util.js +0 -1463
- package/lib/framework/element-util.js.map +0 -1
- package/lib/framework/impl/checkbox/checkbox-impl.js +0 -64
- package/lib/framework/impl/checkbox/checkbox-impl.js.map +0 -1
- package/lib/framework/impl/comments/comment-content-impl.js +0 -105
- package/lib/framework/impl/comments/comment-content-impl.js.map +0 -1
- package/lib/framework/impl/comments/comment-element-impl.js +0 -62
- package/lib/framework/impl/comments/comment-element-impl.js.map +0 -1
- package/lib/framework/impl/comments/comments-container-impl.js +0 -62
- package/lib/framework/impl/comments/comments-container-impl.js.map +0 -1
- package/lib/framework/impl/comments/comments-util.js +0 -67
- package/lib/framework/impl/comments/comments-util.js.map +0 -1
- package/lib/framework/impl/comments/validate-msg-impl.js +0 -83
- package/lib/framework/impl/comments/validate-msg-impl.js.map +0 -1
- package/lib/framework/impl/data-element/data-decorate-impl.js +0 -91
- package/lib/framework/impl/data-element/data-decorate-impl.js.map +0 -1
- package/lib/framework/impl/data-element/data-element-barcode.js +0 -115
- package/lib/framework/impl/data-element/data-element-barcode.js.map +0 -1
- package/lib/framework/impl/data-element/data-element-base-impl.js +0 -205
- package/lib/framework/impl/data-element/data-element-base-impl.js.map +0 -1
- package/lib/framework/impl/data-element/data-element-check-impl.js +0 -133
- package/lib/framework/impl/data-element/data-element-check-impl.js.map +0 -1
- package/lib/framework/impl/data-element/data-element-date-impl.js +0 -111
- package/lib/framework/impl/data-element/data-element-date-impl.js.map +0 -1
- package/lib/framework/impl/data-element/data-element-group-impl.js +0 -130
- package/lib/framework/impl/data-element/data-element-group-impl.js.map +0 -1
- package/lib/framework/impl/data-element/data-element-image-impl.js +0 -137
- package/lib/framework/impl/data-element/data-element-image-impl.js.map +0 -1
- package/lib/framework/impl/data-element/data-element-list-impl.js +0 -131
- package/lib/framework/impl/data-element/data-element-list-impl.js.map +0 -1
- package/lib/framework/impl/data-element/data-element-text-impl.js +0 -103
- package/lib/framework/impl/data-element/data-element-text-impl.js.map +0 -1
- package/lib/framework/impl/decorate/fill-null-space-imple.js +0 -43
- package/lib/framework/impl/decorate/fill-null-space-imple.js.map +0 -1
- package/lib/framework/impl/document/doc-body-impl.js +0 -79
- package/lib/framework/impl/document/doc-body-impl.js.map +0 -1
- package/lib/framework/impl/document/doc-body-part-impl.js +0 -94
- package/lib/framework/impl/document/doc-body-part-impl.js.map +0 -1
- package/lib/framework/impl/document/doc-container-impl.js +0 -21
- package/lib/framework/impl/document/doc-container-impl.js.map +0 -1
- package/lib/framework/impl/document/doc-footer-impl.js +0 -77
- package/lib/framework/impl/document/doc-footer-impl.js.map +0 -1
- package/lib/framework/impl/document/doc-header-impl.js +0 -83
- package/lib/framework/impl/document/doc-header-impl.js.map +0 -1
- package/lib/framework/impl/document/doc-impl.js +0 -209
- package/lib/framework/impl/document/doc-impl.js.map +0 -1
- package/lib/framework/impl/media-formula/menstrual-history.js +0 -153
- package/lib/framework/impl/media-formula/menstrual-history.js.map +0 -1
- package/lib/framework/impl/paragraph/p-impl.js +0 -156
- package/lib/framework/impl/paragraph/p-impl.js.map +0 -1
- package/lib/framework/impl/picture/image-impl.js +0 -124
- package/lib/framework/impl/picture/image-impl.js.map +0 -1
- package/lib/framework/impl/radio/radio-impl.js +0 -72
- package/lib/framework/impl/radio/radio-impl.js.map +0 -1
- package/lib/framework/impl/symbol/br-symbol-impl.js +0 -54
- package/lib/framework/impl/symbol/br-symbol-impl.js.map +0 -1
- package/lib/framework/impl/symbol/p-symbol-impl.js +0 -54
- package/lib/framework/impl/symbol/p-symbol-impl.js.map +0 -1
- package/lib/framework/impl/table/table-cell-impl.js +0 -145
- package/lib/framework/impl/table/table-cell-impl.js.map +0 -1
- package/lib/framework/impl/table/table-impl.js +0 -363
- package/lib/framework/impl/table/table-impl.js.map +0 -1
- package/lib/framework/impl/table/table-row-impl.js +0 -75
- package/lib/framework/impl/table/table-row-impl.js.map +0 -1
- package/lib/framework/impl/table/table-split-cell-patch.js +0 -89
- package/lib/framework/impl/table/table-split-cell-patch.js.map +0 -1
- package/lib/framework/impl/table/table-split-cell.js +0 -464
- package/lib/framework/impl/table/table-split-cell.js.map +0 -1
- package/lib/framework/impl/table/table-util.js +0 -678
- package/lib/framework/impl/table/table-util.js.map +0 -1
- package/lib/framework/impl/text/text-impl.js +0 -149
- package/lib/framework/impl/text/text-impl.js.map +0 -1
- package/lib/framework/impl/text/track-run-impl.js +0 -112
- package/lib/framework/impl/text/track-run-impl.js.map +0 -1
- package/lib/framework/notify.js +0 -116
- package/lib/framework/notify.js.map +0 -1
- package/lib/framework/range-util.js +0 -312
- package/lib/framework/range-util.js.map +0 -1
- package/lib/framework/render-context.js +0 -384
- package/lib/framework/render-context.js.map +0 -1
- package/lib/framework/render-define.js +0 -195
- package/lib/framework/render-define.js.map +0 -1
- package/lib/framework/selection-overlays.js +0 -124
- package/lib/framework/selection-overlays.js.map +0 -1
- package/lib/texteditor.js +0 -913
- package/lib/texteditor.js.map +0 -1
- package/lib/util/subject.js +0 -88
- package/lib/util/subject.js.map +0 -1
- package/lib/util/table-bind.js +0 -6
- package/lib/util/table-bind.js.map +0 -1
@@ -1,145 +0,0 @@
|
|
1
|
-
import { BlockContainerElement, ElementFactory, PaddingProps } from "../../element-define";
|
2
|
-
import { TableCellProps } from "../../element-props";
|
3
|
-
import { ElementUtil } from "../../element-util";
|
4
|
-
import { InlineMuiltBlockLineRenderObject } from "../../render-define";
|
5
|
-
export class TableCellElement extends BlockContainerElement {
|
6
|
-
//props: TableCellProps;
|
7
|
-
constructor() {
|
8
|
-
super('tbc');
|
9
|
-
this.props = new TableCellProps();
|
10
|
-
//this.addPropValueChangedSub(this.props);
|
11
|
-
}
|
12
|
-
beginMeasure() {
|
13
|
-
super.beginMeasure();
|
14
|
-
this.disableClick = !this.isNotBeMergedCell();
|
15
|
-
}
|
16
|
-
/**
|
17
|
-
* 不被合并单元格的单元格
|
18
|
-
* @returns
|
19
|
-
*/
|
20
|
-
isNotBeMergedCell() {
|
21
|
-
return this.props.hMerge !== 'continue' && this.props.vMerge !== 'continue';
|
22
|
-
}
|
23
|
-
createRenderObject() {
|
24
|
-
if (!this.isNotBeMergedCell()) {
|
25
|
-
return null;
|
26
|
-
}
|
27
|
-
const { cellWidth, cellOffset } = this.getCellWidth();
|
28
|
-
const cellRender = new TableCellRenderObject(this);
|
29
|
-
cellRender.rect.width = cellWidth;
|
30
|
-
cellRender.rect.maxWidth = cellWidth;
|
31
|
-
cellRender.padding = new PaddingProps(0, 0, 5, 5);
|
32
|
-
cellRender.rect.x = cellOffset;
|
33
|
-
return cellRender;
|
34
|
-
}
|
35
|
-
serialize(options) {
|
36
|
-
return {
|
37
|
-
type: 'tbc',
|
38
|
-
props: {
|
39
|
-
...this.props.getSerializeProps(options)
|
40
|
-
}
|
41
|
-
};
|
42
|
-
}
|
43
|
-
clone(data) {
|
44
|
-
const clone = new TableCellElement();
|
45
|
-
this.props.clone(clone.props);
|
46
|
-
if (data) {
|
47
|
-
for (let i = 0; i < this.length; i++) {
|
48
|
-
clone.addChild(this.getChild(i).clone(true));
|
49
|
-
}
|
50
|
-
}
|
51
|
-
return clone;
|
52
|
-
}
|
53
|
-
getCellWidth() {
|
54
|
-
const row = this.parent;
|
55
|
-
if (!row) {
|
56
|
-
throw new Error('row is null');
|
57
|
-
}
|
58
|
-
const table = row.parent;
|
59
|
-
const cellIndex = row.getChildIndex(this);
|
60
|
-
let cellWidth = table.getCellWidth(cellIndex);
|
61
|
-
const cellOffset = table.getCellOffsetX(cellIndex);
|
62
|
-
if (this.props.hMerge === 'restart') {
|
63
|
-
for (let i = cellIndex + 1; i < table.getColsCount(); i++) {
|
64
|
-
const nextCell = row.getChild(i);
|
65
|
-
if (nextCell.props.hMerge === 'continue') {
|
66
|
-
cellWidth += table.getCellWidth(i);
|
67
|
-
}
|
68
|
-
else {
|
69
|
-
break;
|
70
|
-
}
|
71
|
-
}
|
72
|
-
}
|
73
|
-
return { cellWidth, cellOffset };
|
74
|
-
}
|
75
|
-
static createCell() {
|
76
|
-
const tc = new TableCellElement();
|
77
|
-
return tc;
|
78
|
-
}
|
79
|
-
}
|
80
|
-
export class TableCellRenderObject extends InlineMuiltBlockLineRenderObject {
|
81
|
-
prevGlobalAlpha = 1;
|
82
|
-
beginRender(ctx, position) {
|
83
|
-
ctx.contentContext.clip(position.x, position.y, this.rect.width, this.rect.height);
|
84
|
-
const { hMerge, vMerge, backgroundColor, diagonal } = this.element.props;
|
85
|
-
if (hMerge === 'continue' || vMerge === 'continue') {
|
86
|
-
this.prevGlobalAlpha = ctx.contentContext.getGlobalAlpha();
|
87
|
-
ctx.contentContext.setGlobalAlpha(0);
|
88
|
-
ctx.overlaysContext.setGlobalAlpha(0);
|
89
|
-
}
|
90
|
-
if (backgroundColor && this.rect.width && this.rect.height) {
|
91
|
-
ctx.contentContext.fillRect(position.x, position.y, this.rect.width, this.rect.height, backgroundColor);
|
92
|
-
}
|
93
|
-
if (diagonal && this.rect.width && this.rect.height) {
|
94
|
-
let diagonalStartX = diagonal === 'main' ? position.x : position.x + this.rect.width;
|
95
|
-
let diagonalStartY = position.y;
|
96
|
-
let diagonalEndX = diagonal === 'main' ? position.x + this.rect.width : position.x;
|
97
|
-
let diagonalEndY = position.y + this.rect.height;
|
98
|
-
ctx.contentContext.strokeLines([{ x: diagonalStartX, y: diagonalStartY }, { x: diagonalEndX, y: diagonalEndY }]);
|
99
|
-
}
|
100
|
-
}
|
101
|
-
endRender(ctx, position) {
|
102
|
-
ctx.contentContext.ctx.restore();
|
103
|
-
if (!this.element.parent) {
|
104
|
-
throw new Error('parent is null');
|
105
|
-
}
|
106
|
-
const tb = this.element.parent.parent;
|
107
|
-
const tbProps = tb.props;
|
108
|
-
if (tbProps.border === 'all') {
|
109
|
-
//ctx.contentContext.strokeRect(position.x, position.y, this.rect.width, this.rect.height, '#000', 1);
|
110
|
-
//ctx.contentContext.roundRect(position.x, position.y, this.rect.width, this.rect.height, 5, false, true);
|
111
|
-
}
|
112
|
-
const { hMerge, vMerge } = this.element.props;
|
113
|
-
if (hMerge === 'continue' || vMerge === 'continue') {
|
114
|
-
ctx.contentContext.setGlobalAlpha(1);
|
115
|
-
ctx.overlaysContext.setGlobalAlpha(1);
|
116
|
-
}
|
117
|
-
}
|
118
|
-
clone() {
|
119
|
-
const cloneRender = new TableCellRenderObject(this.element);
|
120
|
-
cloneRender.rect = ElementUtil.cloneRect(this.rect);
|
121
|
-
cloneRender.padding = this.padding?.clone();
|
122
|
-
cloneRender.margin = this.margin?.clone();
|
123
|
-
for (let i = 0; i < this.length; i++) {
|
124
|
-
cloneRender.addChild(this.getChild(i).clone());
|
125
|
-
}
|
126
|
-
return cloneRender;
|
127
|
-
}
|
128
|
-
}
|
129
|
-
export class TableCellFactory extends ElementFactory {
|
130
|
-
match(type) {
|
131
|
-
return type === 'tbc';
|
132
|
-
}
|
133
|
-
createElement(data, renderCtx) {
|
134
|
-
const tc = new TableCellElement();
|
135
|
-
const props = data.props;
|
136
|
-
tc.props.vMerge = props?.vMerge ?? null;
|
137
|
-
tc.props.hMerge = props?.hMerge ?? null;
|
138
|
-
tc.props.vAlign = props?.vAlign ?? null;
|
139
|
-
tc.props.backgroundColor = props?.backgroundColor ?? null;
|
140
|
-
tc.props.diagonal = props?.diagonal ?? null;
|
141
|
-
//tc.renderCtx = renderCtx;
|
142
|
-
return tc;
|
143
|
-
}
|
144
|
-
}
|
145
|
-
//# sourceMappingURL=table-cell-impl.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"table-cell-impl.js","sourceRoot":"lib/","sources":["framework/impl/table/table-cell-impl.ts"],"names":[],"mappings":"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","sourcesContent":["import { BlockContainerElement, Element, ElementFactory, PaddingProps, readElementProps, SerializeProps, ViewOptions } from \"../../element-define\";\nimport { TableCellProps } from \"../../element-props\";\nimport { ElementUtil } from \"../../element-util\";\nimport { RenderContenxtType } from \"../../render-context\";\nimport { InlineMuiltBlockLineRenderObject, RenderObject } from \"../../render-define\";\nimport { TableElement } from \"./table-impl\";\n\nexport class TableCellElement extends BlockContainerElement<TableCellProps> {\n //props: TableCellProps;\n constructor() {\n super('tbc');\n this.props = new TableCellProps();\n //this.addPropValueChangedSub(this.props);\n }\n\n beginMeasure(): void {\n super.beginMeasure();\n this.disableClick = !this.isNotBeMergedCell();\n }\n\n /**\n * 不被合并单元格的单元格\n * @returns \n */\n isNotBeMergedCell(): boolean {\n return this.props.hMerge !== 'continue' && this.props.vMerge !== 'continue';\n }\n\n createRenderObject(): RenderObject | null {\n if (!this.isNotBeMergedCell()) {\n return null;\n }\n const { cellWidth, cellOffset } = this.getCellWidth();\n const cellRender = new TableCellRenderObject(this);\n cellRender.rect.width = cellWidth;\n cellRender.rect.maxWidth = cellWidth;\n cellRender.padding = new PaddingProps(0, 0, 5, 5);\n cellRender.rect.x = cellOffset;\n return cellRender;\n }\n serialize(options: ViewOptions): SerializeProps {\n return {\n type: 'tbc',\n props: {\n ...this.props.getSerializeProps(options)\n }\n };\n }\n clone(data: boolean): Element {\n const clone = new TableCellElement();\n this.props.clone(clone.props);\n if (data) {\n for (let i = 0; i < this.length; i++) {\n clone.addChild(this.getChild(i).clone(true));\n }\n }\n return clone;\n }\n getCellWidth(): { cellWidth: number, cellOffset: number } {\n const row = this.parent;\n if (!row) {\n throw new Error('row is null');\n }\n const table = row.parent as TableElement;\n const cellIndex = row.getChildIndex(this);\n let cellWidth = table.getCellWidth(cellIndex);\n const cellOffset = table.getCellOffsetX(cellIndex);\n if (this.props.hMerge === 'restart') {\n for (let i = cellIndex + 1; i < table.getColsCount(); i++) {\n const nextCell = row.getChild(i) as TableCellElement;\n if (nextCell.props.hMerge === 'continue') {\n cellWidth += table.getCellWidth(i);\n } else {\n break;\n }\n }\n }\n return { cellWidth, cellOffset };\n }\n\n static createCell(): TableCellElement {\n const tc = new TableCellElement();\n return tc;\n }\n\n}\n\nexport class TableCellRenderObject extends InlineMuiltBlockLineRenderObject {\n private prevGlobalAlpha = 1;\n beginRender(ctx: RenderContenxtType, position: { x: number; y: number; }): void {\n ctx.contentContext.clip(position.x, position.y, this.rect.width, this.rect.height);\n const { hMerge, vMerge, backgroundColor, diagonal } = (<TableCellElement>this.element).props;\n if (hMerge === 'continue' || vMerge === 'continue') {\n this.prevGlobalAlpha = ctx.contentContext.getGlobalAlpha();\n ctx.contentContext.setGlobalAlpha(0);\n ctx.overlaysContext.setGlobalAlpha(0);\n }\n if (backgroundColor && this.rect.width && this.rect.height) {\n ctx.contentContext.fillRect(position.x, position.y, this.rect.width, this.rect.height, backgroundColor)\n }\n if (diagonal && this.rect.width && this.rect.height) {\n let diagonalStartX = diagonal === 'main' ? position.x : position.x + this.rect.width;\n let diagonalStartY = position.y;\n let diagonalEndX = diagonal === 'main' ? position.x + this.rect.width : position.x;\n let diagonalEndY = position.y + this.rect.height;\n ctx.contentContext.strokeLines([{ x: diagonalStartX, y: diagonalStartY }, { x: diagonalEndX, y: diagonalEndY }])\n }\n }\n\n endRender(ctx: RenderContenxtType, position: { x: number; y: number; }): void {\n ctx.contentContext.ctx.restore();\n if (!this.element.parent) {\n throw new Error('parent is null');\n }\n const tb = this.element.parent.parent as TableElement;\n const tbProps = tb.props;\n if (tbProps.border === 'all') {\n //ctx.contentContext.strokeRect(position.x, position.y, this.rect.width, this.rect.height, '#000', 1);\n //ctx.contentContext.roundRect(position.x, position.y, this.rect.width, this.rect.height, 5, false, true);\n }\n const { hMerge, vMerge } = (<TableCellElement>this.element).props;\n if (hMerge === 'continue' || vMerge === 'continue') {\n ctx.contentContext.setGlobalAlpha(1);\n ctx.overlaysContext.setGlobalAlpha(1);\n }\n }\n\n clone(): RenderObject {\n const cloneRender = new TableCellRenderObject(this.element);\n cloneRender.rect = ElementUtil.cloneRect(this.rect);\n cloneRender.padding = this.padding?.clone();\n cloneRender.margin = this.margin?.clone();\n for (let i = 0; i < this.length; i++) {\n cloneRender.addChild(this.getChild(i).clone());\n }\n return cloneRender;\n }\n}\n\nexport class TableCellFactory extends ElementFactory<TableCellProps> {\n match(type: string): boolean {\n return type === 'tbc';\n }\n createElement(data: readElementProps<TableCellProps>, renderCtx: RenderContenxtType): Element {\n const tc = new TableCellElement();\n const props = data.props;\n tc.props.vMerge = props?.vMerge ?? null;\n tc.props.hMerge = props?.hMerge ?? null;\n tc.props.vAlign = props?.vAlign ?? null;\n tc.props.backgroundColor = props?.backgroundColor ?? null;\n tc.props.diagonal = props?.diagonal ?? null;\n //tc.renderCtx = renderCtx;\n return tc;\n }\n\n}\n"]}
|
@@ -1,363 +0,0 @@
|
|
1
|
-
import { BlockContainerElement, ElementFactory } from "../../element-define";
|
2
|
-
import { TableProps } from "../../element-props";
|
3
|
-
import { ElementUtil } from "../../element-util";
|
4
|
-
import { MuiltBlockLineRenderObject } from "../../render-define";
|
5
|
-
import { ParagraphElement } from "../paragraph/p-impl";
|
6
|
-
import { TableRowElement } from "./table-row-impl";
|
7
|
-
import { TableSplitCell } from "./table-split-cell";
|
8
|
-
import { TableUtil } from "./table-util";
|
9
|
-
/**
|
10
|
-
* 计算表格列
|
11
|
-
*/
|
12
|
-
function calcTableCols(element) {
|
13
|
-
const percentCols = [];
|
14
|
-
let sum = 0;
|
15
|
-
let percentSum = 0;
|
16
|
-
for (const col of element.props.cols) {
|
17
|
-
if (typeof col.width === 'string') {
|
18
|
-
percentCols.push(col);
|
19
|
-
percentSum += Number.parseFloat(col.width);
|
20
|
-
}
|
21
|
-
else {
|
22
|
-
sum += col.width;
|
23
|
-
}
|
24
|
-
}
|
25
|
-
const measureRender = element.measureRender;
|
26
|
-
const tbWidth = measureRender.rect.maxWidth;
|
27
|
-
if (percentCols.length > 0) {
|
28
|
-
const remainWidth = tbWidth - sum;
|
29
|
-
let remainSum = 0;
|
30
|
-
for (const percentCol of percentCols) {
|
31
|
-
const percentWidth = Number.parseFloat(percentCol.width.toString());
|
32
|
-
percentCol.width = Math.floor(remainWidth * percentWidth / percentSum);
|
33
|
-
remainSum += percentCol.width;
|
34
|
-
}
|
35
|
-
if (remainWidth - remainSum > 0) {
|
36
|
-
const colWidth = percentCols[percentCols.length - 1].width;
|
37
|
-
percentCols[percentCols.length - 1].width = colWidth + (remainWidth - remainSum);
|
38
|
-
}
|
39
|
-
}
|
40
|
-
const array = [];
|
41
|
-
let offset = 0;
|
42
|
-
for (let i = 0; i < element.props.cols.length; i++) {
|
43
|
-
const width = element.props.cols[i].width;
|
44
|
-
array.push({ width, offset });
|
45
|
-
offset += width;
|
46
|
-
}
|
47
|
-
return array;
|
48
|
-
}
|
49
|
-
export class TableElement extends BlockContainerElement {
|
50
|
-
//props: TableProps;
|
51
|
-
_actualColsProps;
|
52
|
-
constructor() {
|
53
|
-
super('tb');
|
54
|
-
this.props = new TableProps();
|
55
|
-
//this.addPropValueChangedSub(this.props);
|
56
|
-
this.addEvent('ElementContextMenu', (evt) => {
|
57
|
-
const { selectionState } = evt;
|
58
|
-
if (TableUtil.canDeleteTable(selectionState)) {
|
59
|
-
evt.menus.push({
|
60
|
-
icon: 'DeleteTable', caption: '删除表格', eventObj: {
|
61
|
-
onClick: (cevt) => {
|
62
|
-
selectionState.clear();
|
63
|
-
const prevEle = ElementUtil.getRecursionPrevSiblingElement(this, false, true);
|
64
|
-
if (prevEle) {
|
65
|
-
selectionState.resetRange(prevEle, -1);
|
66
|
-
}
|
67
|
-
this.remove();
|
68
|
-
this.destroy();
|
69
|
-
}
|
70
|
-
}
|
71
|
-
});
|
72
|
-
}
|
73
|
-
if (TableUtil.canMergeCells(selectionState)) {
|
74
|
-
evt.menus.push({ icon: 'MergeDuplicate', caption: '合并单元格', eventObj: { onClick: (cevt) => { TableUtil.mergeCells(selectionState); } } });
|
75
|
-
}
|
76
|
-
if (TableUtil.canSplitCell(selectionState)) {
|
77
|
-
evt.menus.push({ icon: 'Split', caption: '拆分单元格', eventObj: { onClick: (cevt) => { TableSplitCell.splitCell(selectionState, 0, 2); } } });
|
78
|
-
evt.menus.push({ icon: 'Combine', caption: '合并单元格还原', eventObj: { onClick: (cevt) => { TableUtil.restoreCell(selectionState); } } });
|
79
|
-
}
|
80
|
-
evt.menus.push({ icon: "Insert", caption: '上方插入段落', eventObj: { onClick: (cevt) => { this.parent.addChild(ParagraphElement.createElement(), this.getIndex()); this.refreshView(); } } });
|
81
|
-
evt.menus.push({ icon: "Insert", caption: '下方插入段落', eventObj: { onClick: (cevt) => { this.parent.addChild(ParagraphElement.createElement(), this.getIndex() + 1); this.refreshView(); } } });
|
82
|
-
evt.menus = removeDuplicatesEvent(evt.menus);
|
83
|
-
}, true);
|
84
|
-
this.addEvent('ElementKeyDown', (evt) => {
|
85
|
-
//console.log('表格ElementKeyDown', evt);
|
86
|
-
const sourceEvent = evt.sourceEvent;
|
87
|
-
//按下tab键
|
88
|
-
if (sourceEvent.keyCode === 9 && !sourceEvent.shiftKey) {
|
89
|
-
evt.isCancel = true;
|
90
|
-
sourceEvent.preventDefault();
|
91
|
-
TableUtil.moveNextCell(evt.selectionState);
|
92
|
-
}
|
93
|
-
}, true);
|
94
|
-
}
|
95
|
-
/**
|
96
|
-
* 获取实际测量的宽度,将auto、百分比列宽度进行转化为 number 类型
|
97
|
-
*/
|
98
|
-
get actualColsProps() {
|
99
|
-
if (!this._actualColsProps) {
|
100
|
-
this._actualColsProps = calcTableCols(this);
|
101
|
-
}
|
102
|
-
return this._actualColsProps;
|
103
|
-
}
|
104
|
-
getCellWidth(cellIndex) {
|
105
|
-
if (cellIndex >= this.actualColsProps.length || cellIndex < 0) {
|
106
|
-
return -1;
|
107
|
-
}
|
108
|
-
return this.actualColsProps[cellIndex].width;
|
109
|
-
}
|
110
|
-
getCellOffsetX(cellIndex) {
|
111
|
-
return this.actualColsProps[cellIndex].offset;
|
112
|
-
}
|
113
|
-
setCellWidth(cellIndex, width) {
|
114
|
-
//this.actualColsProps[index].width = width;
|
115
|
-
if (cellIndex >= this.actualColsProps.length || cellIndex < 0) {
|
116
|
-
return;
|
117
|
-
}
|
118
|
-
this.props.cols[cellIndex].width = width;
|
119
|
-
}
|
120
|
-
/**
|
121
|
-
* 插入列的定义
|
122
|
-
* @param index
|
123
|
-
* @param width
|
124
|
-
*/
|
125
|
-
insertCol(index, width) {
|
126
|
-
this.props.cols.splice(index, 0, { width });
|
127
|
-
this._actualColsProps = null;
|
128
|
-
}
|
129
|
-
/**
|
130
|
-
* 移除列的定义
|
131
|
-
* @param index
|
132
|
-
*/
|
133
|
-
removeCol(index) {
|
134
|
-
this.props.cols.splice(index, 1);
|
135
|
-
}
|
136
|
-
getColsCount() {
|
137
|
-
return this.actualColsProps.length;
|
138
|
-
}
|
139
|
-
clone(data) {
|
140
|
-
const clone = new TableElement();
|
141
|
-
this.props.clone(clone.props);
|
142
|
-
if (data) {
|
143
|
-
for (let i = 0; i < this.length; i++) {
|
144
|
-
clone.addChild(this.getChild(i).clone(true));
|
145
|
-
}
|
146
|
-
}
|
147
|
-
return clone;
|
148
|
-
}
|
149
|
-
createRenderObject(options, renderCtx) {
|
150
|
-
return new TableRenderObject(this);
|
151
|
-
}
|
152
|
-
beginMeasure() {
|
153
|
-
super.beginMeasure();
|
154
|
-
this._actualColsProps = null;
|
155
|
-
}
|
156
|
-
serialize(options) {
|
157
|
-
//this.props.width = this.measureRender?.rect.width as number;
|
158
|
-
const props = {
|
159
|
-
type: 'tb',
|
160
|
-
props: { ...this.props.getSerializeProps(options) }
|
161
|
-
};
|
162
|
-
props.props.width = this.measureRender?.rect.width;
|
163
|
-
return props;
|
164
|
-
}
|
165
|
-
static createTable(rows, cols) {
|
166
|
-
const table = new TableElement();
|
167
|
-
const tbProps = new TableProps();
|
168
|
-
table.props = tbProps;
|
169
|
-
tbProps.border = 'all';
|
170
|
-
tbProps.cols = [];
|
171
|
-
for (let i = 0; i < cols; i++) {
|
172
|
-
tbProps.cols.push({ width: "1" });
|
173
|
-
}
|
174
|
-
for (let i = 0; i < rows; i++) {
|
175
|
-
table.addChild(TableRowElement.createRow(cols));
|
176
|
-
}
|
177
|
-
return table;
|
178
|
-
}
|
179
|
-
}
|
180
|
-
function removeDuplicatesEvent(events) {
|
181
|
-
let arr = [];
|
182
|
-
for (let i = events.length - 1; i >= 0; i--) {
|
183
|
-
let keys = arr.map(item => item.caption);
|
184
|
-
if (!keys.includes(events[i].caption)) {
|
185
|
-
arr.unshift(events[i]);
|
186
|
-
}
|
187
|
-
}
|
188
|
-
return arr;
|
189
|
-
}
|
190
|
-
export class TableRenderObject extends MuiltBlockLineRenderObject {
|
191
|
-
setRenderWidth(maxWidth) {
|
192
|
-
super.setRenderWidth(maxWidth);
|
193
|
-
}
|
194
|
-
beginRender(ctx, position) {
|
195
|
-
//绘制表格线
|
196
|
-
if (this.element.props.border !== 'all') {
|
197
|
-
return;
|
198
|
-
}
|
199
|
-
for (let i = 0; i < this.length; i++) {
|
200
|
-
const rowRender = this.getChild(i);
|
201
|
-
const rowPos = { x: rowRender.rect.x + position.x, y: rowRender.rect.y + position.y };
|
202
|
-
for (let j = 0; j < rowRender.length; j++) {
|
203
|
-
const cellRender = rowRender.getChild(j);
|
204
|
-
const cellPos = { x: cellRender.rect.x + rowPos.x, y: cellRender.rect.y + rowPos.y };
|
205
|
-
//绘制单元格上边框
|
206
|
-
if (i === 0) {
|
207
|
-
//ctx.contentContext.fillRect(cellPos.x, cellPos.y, cellRender.rect.width, 1);
|
208
|
-
ctx.contentContext.fillLines([{ x: cellPos.x, y: cellPos.y }, { x: cellPos.x + cellRender.rect.width, y: cellPos.y }]);
|
209
|
-
//this.drawLine(ctx, { x: cellPos.x, y: cellPos.y }, { x: cellPos.x + cellRender.rect.width, y: cellPos.y });
|
210
|
-
}
|
211
|
-
//绘制左边框
|
212
|
-
if (j === 0) {
|
213
|
-
//ctx.contentContext.fillRect(cellPos.x, cellPos.y, 1, cellRender.rect.height);
|
214
|
-
ctx.contentContext.fillLines([{ x: cellPos.x, y: cellPos.y }, { x: cellPos.x, y: cellPos.y + cellRender.rect.height }]);
|
215
|
-
//this.drawLine(ctx, { x: cellPos.x, y: cellPos.y }, { x: cellPos.x, y: cellPos.y + cellRender.rect.height });
|
216
|
-
}
|
217
|
-
//绘制右边框
|
218
|
-
//ctx.contentContext.fillRect(cellPos.x + cellRender.rect.width, cellPos.y, 1, cellRender.rect.height);
|
219
|
-
ctx.contentContext.fillLines([{ x: cellPos.x + cellRender.rect.width, y: cellPos.y }, { x: cellPos.x + cellRender.rect.width, y: cellPos.y + cellRender.rect.height }]);
|
220
|
-
//this.drawLine(ctx, { x: cellPos.x + cellRender.rect.width, y: cellPos.y }, { x: cellPos.x + cellRender.rect.width, y: cellPos.y + cellRender.rect.height });
|
221
|
-
//绘制下边框
|
222
|
-
//ctx.contentContext.fillRect(cellPos.x, cellPos.y + cellRender.rect.height, cellRender.rect.width, 1);
|
223
|
-
ctx.contentContext.fillLines([{ x: cellPos.x, y: cellPos.y + cellRender.rect.height }, { x: cellPos.x + cellRender.rect.width, y: cellPos.y + cellRender.rect.height }]);
|
224
|
-
//this.drawLine(ctx, { x: cellPos.x, y: cellPos.y + cellRender.rect.height }, { x: cellPos.x + cellRender.rect.width, y: cellPos.y + cellRender.rect.height });
|
225
|
-
//cellRender.beginRender(ctx, { x: position.x + cellRender.offsetX, y: position.y + cellRender.offsetY });
|
226
|
-
}
|
227
|
-
}
|
228
|
-
}
|
229
|
-
endRender(ctx, position) {
|
230
|
-
}
|
231
|
-
clone() {
|
232
|
-
const cloneRender = new TableRenderObject(this.element);
|
233
|
-
cloneRender.rect = ElementUtil.cloneRect(this.rect);
|
234
|
-
for (let i = 0; i < this.length; i++) {
|
235
|
-
cloneRender.addChild(this.getChild(i).clone());
|
236
|
-
}
|
237
|
-
return cloneRender;
|
238
|
-
}
|
239
|
-
}
|
240
|
-
export class TableFactory extends ElementFactory {
|
241
|
-
match(type) {
|
242
|
-
return type === 'tb';
|
243
|
-
}
|
244
|
-
createElement(data, renderCtx) {
|
245
|
-
const props = data.props;
|
246
|
-
const tb = new TableElement();
|
247
|
-
const cols = props.cols;
|
248
|
-
const tbProps = tb.props;
|
249
|
-
tbProps.border = props.border || 'all';
|
250
|
-
tbProps.cols = [];
|
251
|
-
for (const col of cols) {
|
252
|
-
tbProps.cols.push({
|
253
|
-
width: col.width
|
254
|
-
});
|
255
|
-
}
|
256
|
-
tb.props = tbProps;
|
257
|
-
return tb;
|
258
|
-
}
|
259
|
-
}
|
260
|
-
/**
|
261
|
-
* 行-表格渲染模式
|
262
|
-
*/
|
263
|
-
export function textLineRenderMode(ele, options, renderCtx) {
|
264
|
-
const tb = ele.measureRender;
|
265
|
-
const rows = [];
|
266
|
-
for (let i = 0; i < tb.length; i++) {
|
267
|
-
const row = tb.getChild(i);
|
268
|
-
//表格头不做处理
|
269
|
-
if (row.element.props.headerRow) {
|
270
|
-
continue;
|
271
|
-
}
|
272
|
-
rows.push(row);
|
273
|
-
}
|
274
|
-
for (let i = 0; i < rows.length; i++) {
|
275
|
-
const row = rows[i];
|
276
|
-
//获取当前行的文字行数
|
277
|
-
const maxLinesCount = getRowMaxTextLines(row);
|
278
|
-
if (maxLinesCount > 1) {
|
279
|
-
for (let j = 1; j < maxLinesCount; j++) {
|
280
|
-
const newRow = row.element.createRenderObject();
|
281
|
-
newRow.rect = ElementUtil.cloneRect(row.rect);
|
282
|
-
tb.insertChild(newRow, row.getIndex() + 1);
|
283
|
-
//复制行文字到新行中
|
284
|
-
for (let k = 0; k < row.length; k++) {
|
285
|
-
const cell = row.getChild(k);
|
286
|
-
const newCell = cell.element.createRenderObject(options, renderCtx);
|
287
|
-
newCell.rect = ElementUtil.cloneRect(cell.rect);
|
288
|
-
if (newCell) {
|
289
|
-
newRow.addChild(newCell);
|
290
|
-
}
|
291
|
-
}
|
292
|
-
}
|
293
|
-
}
|
294
|
-
splitTextlineToNewRow(row, maxLinesCount, options, renderCtx);
|
295
|
-
}
|
296
|
-
ElementUtil.remeasure(tb);
|
297
|
-
return true;
|
298
|
-
}
|
299
|
-
/**
|
300
|
-
* 获取当前行的文字行数
|
301
|
-
* @param row
|
302
|
-
* @returns
|
303
|
-
*/
|
304
|
-
function getRowMaxTextLines(row) {
|
305
|
-
let count = 0;
|
306
|
-
for (let j = 0; j < row.length; j++) {
|
307
|
-
const cell = row.getChild(j);
|
308
|
-
let cellMaxLines = 0;
|
309
|
-
for (let k = 0; k < cell.length; k++) {
|
310
|
-
const paraRender = cell.getChild(k);
|
311
|
-
cellMaxLines += paraRender.length;
|
312
|
-
}
|
313
|
-
count = cellMaxLines > count ? cellMaxLines : count;
|
314
|
-
}
|
315
|
-
return count;
|
316
|
-
}
|
317
|
-
/**
|
318
|
-
* 将多行文本移动到新行中
|
319
|
-
* @param row
|
320
|
-
* @param maxLinesCount
|
321
|
-
* @returns
|
322
|
-
*/
|
323
|
-
function splitTextlineToNewRow(row, maxLinesCount, options, renderCtx) {
|
324
|
-
if (maxLinesCount === 1) {
|
325
|
-
return;
|
326
|
-
}
|
327
|
-
for (let i = 0; i < row.length; i++) {
|
328
|
-
const cell = row.getChild(i);
|
329
|
-
const paraLines = ElementUtil.getCellParaLines(cell);
|
330
|
-
if (paraLines.length === 1) {
|
331
|
-
continue;
|
332
|
-
}
|
333
|
-
for (let j = 1; j < paraLines.length; j++) {
|
334
|
-
const outterLineRect = paraLines[j];
|
335
|
-
const paraRender = outterLineRect.parent;
|
336
|
-
const newParaRender = paraRender.element.createRenderObject(options, renderCtx);
|
337
|
-
newParaRender.rect = ElementUtil.cloneRect(paraRender.rect);
|
338
|
-
const newOutterLineRect = outterLineRect.clone();
|
339
|
-
newOutterLineRect.rect = ElementUtil.cloneRect(outterLineRect.rect);
|
340
|
-
newParaRender.addChild(newOutterLineRect);
|
341
|
-
paraRender.removeChild(outterLineRect);
|
342
|
-
ElementUtil.remeasure(paraRender);
|
343
|
-
if (paraRender.length === 0) {
|
344
|
-
cell.removeChild(paraRender);
|
345
|
-
}
|
346
|
-
const splitRow = row.parent.getChild(row.getIndex() + j);
|
347
|
-
const splitCell = splitRow.getChild(i);
|
348
|
-
splitCell.addChild(newParaRender);
|
349
|
-
ElementUtil.remeasure(newParaRender);
|
350
|
-
}
|
351
|
-
}
|
352
|
-
const tb = row.parent;
|
353
|
-
const rowIndex = row.getIndex();
|
354
|
-
for (let i = 0; i < maxLinesCount; i++) {
|
355
|
-
const row = tb.getChild(rowIndex + i);
|
356
|
-
for (let j = 0; j < row.length; j++) {
|
357
|
-
const cell = row.getChild(j);
|
358
|
-
ElementUtil.remeasure(cell);
|
359
|
-
}
|
360
|
-
ElementUtil.remeasure(row);
|
361
|
-
}
|
362
|
-
}
|
363
|
-
//# sourceMappingURL=table-impl.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"table-impl.js","sourceRoot":"lib/","sources":["framework/impl/table/table-impl.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n BlockContainerElement,\n Element,\n ElementFactory,\n Position,\n SerializeProps,\n ViewOptions\n} from \"../../element-define\";\nimport { ContentMenuItem, ContextMenuElementEvent, KeyboradElementEvent } from \"../../element-event-define\";\nimport { TableProps } from \"../../element-props\";\nimport { ElementUtil } from \"../../element-util\";\nimport { RenderContenxtType } from \"../../render-context\";\nimport { MuiltBlockLineRenderObject, RenderObject } from \"../../render-define\";\nimport { ParagraphElement, ParagraphRenderObject } from \"../paragraph/p-impl\";\nimport { TableCellRenderObject } from \"./table-cell-impl\";\nimport { TableRowElement, TableRowRenderObject } from \"./table-row-impl\";\nimport { TableSplitCell } from \"./table-split-cell\";\nimport { TableUtil } from \"./table-util\";\n\n/**\n * 计算表格列\n */\nfunction calcTableCols(element: TableElement): Array<{ width: number, offset: number }> {\n const percentCols: Array<{ width: string | number }> = [];\n let sum = 0;\n let percentSum = 0;\n for (const col of element.props.cols) {\n if (typeof col.width === 'string') {\n percentCols.push(col);\n percentSum += Number.parseFloat(col.width);\n } else {\n sum += col.width as number;\n }\n }\n const measureRender = element.measureRender as RenderObject;\n const tbWidth = measureRender.rect.maxWidth as number;\n if (percentCols.length > 0) {\n const remainWidth = tbWidth - sum;\n let remainSum = 0;\n for (const percentCol of percentCols) {\n const percentWidth = Number.parseFloat(percentCol.width.toString());\n\n percentCol.width = Math.floor(remainWidth * percentWidth / percentSum);\n remainSum += percentCol.width as number;\n }\n if (remainWidth - remainSum > 0) {\n const colWidth = percentCols[percentCols.length - 1].width as number;\n percentCols[percentCols.length - 1].width = colWidth + (remainWidth - remainSum);\n }\n }\n const array: Array<{ width: number, offset: number }> = [];\n let offset = 0;\n for (let i = 0; i < element.props.cols.length; i++) {\n const width = element.props.cols[i].width as number;\n array.push({ width, offset });\n offset += width;\n }\n return array;\n}\n\nexport class TableElement extends BlockContainerElement<TableProps> {\n //props: TableProps;\n private _actualColsProps!: Array<{ width: number, offset: number }> | null;\n constructor() {\n super('tb');\n this.props = new TableProps();\n //this.addPropValueChangedSub(this.props);\n this.addEvent<ContextMenuElementEvent>('ElementContextMenu', (evt) => {\n const { selectionState } = evt;\n if (TableUtil.canDeleteTable(selectionState)) {\n evt.menus.push({\n icon: 'DeleteTable', caption: '删除表格', eventObj: {\n onClick: (cevt) => {\n selectionState.clear();\n const prevEle = ElementUtil.getRecursionPrevSiblingElement(this, false, true);\n if (prevEle) {\n selectionState.resetRange(prevEle, -1);\n }\n this.remove();\n this.destroy();\n }\n }\n });\n }\n if (TableUtil.canMergeCells(selectionState)) {\n evt.menus.push({ icon: 'MergeDuplicate', caption: '合并单元格', eventObj: { onClick: (cevt) => { TableUtil.mergeCells(selectionState) } } });\n }\n if (TableUtil.canSplitCell(selectionState)) {\n evt.menus.push({ icon: 'Split', caption: '拆分单元格', eventObj: { onClick: (cevt) => { TableSplitCell.splitCell(selectionState, 0, 2) } } });\n evt.menus.push({ icon: 'Combine', caption: '合并单元格还原', eventObj: { onClick: (cevt) => { TableUtil.restoreCell(selectionState) } } });\n\n }\n evt.menus.push({ icon: \"Insert\", caption: '上方插入段落', eventObj: { onClick: (cevt) => { this.parent.addChild(ParagraphElement.createElement(), this.getIndex()); this.refreshView() } } });\n evt.menus.push({ icon: \"Insert\", caption: '下方插入段落', eventObj: { onClick: (cevt) => { this.parent.addChild(ParagraphElement.createElement(), this.getIndex() + 1); this.refreshView() } } });\n\n\n evt.menus = removeDuplicatesEvent(evt.menus);\n }, true);\n this.addEvent<KeyboradElementEvent>('ElementKeyDown', (evt) => {\n //console.log('表格ElementKeyDown', evt);\n const sourceEvent = evt.sourceEvent;\n //按下tab键\n if (sourceEvent.keyCode === 9 && !sourceEvent.shiftKey) {\n evt.isCancel = true;\n sourceEvent.preventDefault();\n TableUtil.moveNextCell(evt.selectionState);\n }\n }, true);\n }\n /**\n * 获取实际测量的宽度,将auto、百分比列宽度进行转化为 number 类型\n */\n get actualColsProps() {\n if (!this._actualColsProps) {\n this._actualColsProps = calcTableCols(this);\n }\n return this._actualColsProps;\n }\n\n getCellWidth(cellIndex: number): number {\n if (cellIndex >= this.actualColsProps.length || cellIndex < 0) {\n return -1;\n }\n return this.actualColsProps[cellIndex].width;\n }\n\n getCellOffsetX(cellIndex: number): number {\n return this.actualColsProps[cellIndex].offset;\n }\n\n setCellWidth(cellIndex: number, width: number): void {\n //this.actualColsProps[index].width = width;\n if (cellIndex >= this.actualColsProps.length || cellIndex < 0) {\n return;\n }\n this.props.cols[cellIndex].width = width;\n }\n\n /**\n * 插入列的定义\n * @param index \n * @param width \n */\n insertCol(index: number, width: number | string): void {\n this.props.cols.splice(index, 0, { width });\n this._actualColsProps = null;\n }\n\n /**\n * 移除列的定义\n * @param index \n */\n removeCol(index: number): void {\n this.props.cols.splice(index, 1);\n }\n\n getColsCount(): number {\n return this.actualColsProps.length;\n }\n clone(data: boolean): Element {\n const clone = new TableElement();\n this.props.clone(clone.props);\n if (data) {\n for (let i = 0; i < this.length; i++) {\n clone.addChild(this.getChild(i).clone(true));\n }\n }\n return clone;\n }\n\n createRenderObject(options: ViewOptions, renderCtx: RenderContenxtType): RenderObject {\n return new TableRenderObject(this);\n }\n\n beginMeasure(): void {\n super.beginMeasure();\n this._actualColsProps = null;\n }\n\n serialize(options: ViewOptions): SerializeProps {\n //this.props.width = this.measureRender?.rect.width as number;\n const props = {\n type: 'tb',\n props: { ...this.props.getSerializeProps(options) }\n }\n props.props.width = this.measureRender?.rect.width as number;\n return props;\n }\n\n static createTable(rows: number, cols: number): TableElement {\n const table = new TableElement();\n const tbProps = new TableProps();\n table.props = tbProps;\n tbProps.border = 'all';\n tbProps.cols = [];\n for (let i = 0; i < cols; i++) {\n tbProps.cols.push({ width: \"1\" });\n }\n for (let i = 0; i < rows; i++) {\n table.addChild(TableRowElement.createRow(cols));\n }\n return table;\n }\n}\n\nfunction removeDuplicatesEvent(events: ContentMenuItem[]): ContentMenuItem[] {\n let arr: ContentMenuItem[] = [];\n for (let i = events.length - 1; i >= 0; i--) {\n let keys = arr.map(item => item.caption);\n if (!keys.includes(events[i].caption)) {\n arr.unshift(events[i]);\n }\n }\n return arr;\n}\n\nexport class TableRenderObject extends MuiltBlockLineRenderObject<TableElement> {\n setRenderWidth(maxWidth: number): void {\n super.setRenderWidth(maxWidth);\n }\n\n beginRender(ctx: RenderContenxtType, position: { x: number; y: number; }): void {\n //绘制表格线\n if (this.element.props.border !== 'all') {\n return;\n }\n for (let i = 0; i < this.length; i++) {\n const rowRender = this.getChild(i) as TableRowRenderObject;\n const rowPos: Position = { x: rowRender.rect.x + position.x, y: rowRender.rect.y + position.y };\n for (let j = 0; j < rowRender.length; j++) {\n const cellRender = rowRender.getChild(j) as TableCellRenderObject;\n const cellPos: Position = { x: cellRender.rect.x + rowPos.x, y: cellRender.rect.y + rowPos.y };\n //绘制单元格上边框\n if (i === 0) {\n //ctx.contentContext.fillRect(cellPos.x, cellPos.y, cellRender.rect.width, 1);\n ctx.contentContext.fillLines([{ x: cellPos.x, y: cellPos.y }, { x: cellPos.x + cellRender.rect.width, y: cellPos.y }]);\n //this.drawLine(ctx, { x: cellPos.x, y: cellPos.y }, { x: cellPos.x + cellRender.rect.width, y: cellPos.y });\n }\n //绘制左边框\n if (j === 0) {\n //ctx.contentContext.fillRect(cellPos.x, cellPos.y, 1, cellRender.rect.height);\n ctx.contentContext.fillLines([{ x: cellPos.x, y: cellPos.y }, { x: cellPos.x, y: cellPos.y + cellRender.rect.height }]);\n //this.drawLine(ctx, { x: cellPos.x, y: cellPos.y }, { x: cellPos.x, y: cellPos.y + cellRender.rect.height });\n }\n //绘制右边框\n //ctx.contentContext.fillRect(cellPos.x + cellRender.rect.width, cellPos.y, 1, cellRender.rect.height);\n ctx.contentContext.fillLines([{ x: cellPos.x + cellRender.rect.width, y: cellPos.y }, { x: cellPos.x + cellRender.rect.width, y: cellPos.y + cellRender.rect.height }]);\n //this.drawLine(ctx, { x: cellPos.x + cellRender.rect.width, y: cellPos.y }, { x: cellPos.x + cellRender.rect.width, y: cellPos.y + cellRender.rect.height });\n //绘制下边框\n //ctx.contentContext.fillRect(cellPos.x, cellPos.y + cellRender.rect.height, cellRender.rect.width, 1);\n ctx.contentContext.fillLines([{ x: cellPos.x, y: cellPos.y + cellRender.rect.height }, { x: cellPos.x + cellRender.rect.width, y: cellPos.y + cellRender.rect.height }]);\n //this.drawLine(ctx, { x: cellPos.x, y: cellPos.y + cellRender.rect.height }, { x: cellPos.x + cellRender.rect.width, y: cellPos.y + cellRender.rect.height });\n //cellRender.beginRender(ctx, { x: position.x + cellRender.offsetX, y: position.y + cellRender.offsetY });\n }\n }\n }\n\n endRender(ctx: RenderContenxtType, position: { x: number; y: number; }): void {\n }\n clone(): RenderObject {\n const cloneRender = new TableRenderObject(this.element);\n cloneRender.rect = ElementUtil.cloneRect(this.rect);\n for (let i = 0; i < this.length; i++) {\n cloneRender.addChild(this.getChild(i).clone());\n }\n return cloneRender;\n }\n}\n\n\nexport class TableFactory extends ElementFactory<TableProps> {\n match(type: string): boolean {\n return type === 'tb';\n }\n createElement(data: any, renderCtx: RenderContenxtType): Element {\n const props = data.props as TableProps;\n const tb = new TableElement();\n const cols = props.cols;\n const tbProps = tb.props;\n tbProps.border = props.border || 'all';\n tbProps.cols = [];\n for (const col of cols) {\n tbProps.cols.push({\n width: col.width\n });\n }\n tb.props = tbProps;\n return tb;\n }\n\n}\n\n/**\n * 行-表格渲染模式\n */\nexport function textLineRenderMode(ele: TableElement, options: ViewOptions, renderCtx: RenderContenxtType): boolean {\n const tb = ele.measureRender as TableRenderObject;\n const rows: Array<TableRowRenderObject> = []\n for (let i = 0; i < tb.length; i++) {\n const row = tb.getChild(i) as TableRowRenderObject;\n //表格头不做处理\n if ((<TableRowElement>row.element).props.headerRow) {\n continue;\n }\n rows.push(row);\n }\n for (let i = 0; i < rows.length; i++) {\n const row = rows[i];\n //获取当前行的文字行数\n const maxLinesCount = getRowMaxTextLines(row);\n if (maxLinesCount > 1) {\n for (let j = 1; j < maxLinesCount; j++) {\n const newRow = row.element.createRenderObject() as TableRowRenderObject;\n newRow.rect = ElementUtil.cloneRect(row.rect);\n tb.insertChild(newRow, row.getIndex() + 1);\n //复制行文字到新行中\n for (let k = 0; k < row.length; k++) {\n const cell = row.getChild(k) as TableCellRenderObject;\n const newCell = cell.element.createRenderObject(options, renderCtx) as TableCellRenderObject\n newCell.rect = ElementUtil.cloneRect(cell.rect);\n if (newCell) {\n newRow.addChild(newCell)\n }\n }\n }\n }\n splitTextlineToNewRow(row, maxLinesCount, options, renderCtx);\n }\n ElementUtil.remeasure(tb);\n return true;\n}\n\n/**\n * 获取当前行的文字行数\n * @param row \n * @returns \n */\nfunction getRowMaxTextLines(row: TableRowRenderObject): number {\n let count = 0;\n for (let j = 0; j < row.length; j++) {\n const cell = row.getChild(j) as TableCellRenderObject;\n let cellMaxLines = 0;\n for (let k = 0; k < cell.length; k++) {\n const paraRender = cell.getChild(k) as ParagraphRenderObject;\n cellMaxLines += paraRender.length;\n }\n count = cellMaxLines > count ? cellMaxLines : count;\n }\n return count;\n}\n\n/**\n * 将多行文本移动到新行中\n * @param row \n * @param maxLinesCount \n * @returns \n */\nfunction splitTextlineToNewRow(row: TableRowRenderObject, maxLinesCount: number, options: ViewOptions, renderCtx: RenderContenxtType): void {\n if (maxLinesCount === 1) {\n return;\n }\n for (let i = 0; i < row.length; i++) {\n const cell = row.getChild(i) as TableCellRenderObject;\n const paraLines = ElementUtil.getCellParaLines(cell);\n if (paraLines.length === 1) {\n continue;\n }\n for (let j = 1; j < paraLines.length; j++) {\n const outterLineRect = paraLines[j];\n const paraRender = outterLineRect.parent as ParagraphRenderObject;\n\n const newParaRender = paraRender.element.createRenderObject(options, renderCtx) as ParagraphRenderObject;\n newParaRender.rect = ElementUtil.cloneRect(paraRender.rect);\n\n const newOutterLineRect = outterLineRect.clone();\n newOutterLineRect.rect = ElementUtil.cloneRect(outterLineRect.rect);\n newParaRender.addChild(newOutterLineRect);\n\n paraRender.removeChild(outterLineRect);\n ElementUtil.remeasure(paraRender);\n\n if (paraRender.length === 0) {\n cell.removeChild(paraRender);\n }\n const splitRow = row.parent.getChild(row.getIndex() + j) as TableRowRenderObject;\n const splitCell = splitRow.getChild(i) as TableCellRenderObject;\n splitCell.addChild(newParaRender);\n ElementUtil.remeasure(newParaRender);\n }\n }\n const tb = row.parent as TableRenderObject;\n const rowIndex = row.getIndex();\n for (let i = 0; i < maxLinesCount; i++) {\n const row = tb.getChild(rowIndex + i) as TableRowRenderObject;\n for (let j = 0; j < row.length; j++) {\n const cell = row.getChild(j) as TableCellRenderObject;\n ElementUtil.remeasure(cell);\n }\n ElementUtil.remeasure(row);\n }\n}\n"]}
|