@hailin-zheng/editor-core 1.0.1 → 1.0.3
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/lib/doc-ruler.d.ts +51 -0
- package/lib/doc-ruler.js +313 -0
- package/lib/doc-ruler.js.map +1 -0
- package/lib/framework/common-util.d.ts +63 -0
- package/lib/framework/common-util.js +178 -0
- package/lib/framework/common-util.js.map +1 -0
- package/lib/framework/document-change.d.ts +265 -0
- package/lib/framework/document-change.js +1342 -0
- package/lib/framework/document-change.js.map +1 -0
- package/lib/framework/document-combine.d.ts +24 -0
- package/lib/framework/document-combine.js +40 -0
- package/lib/framework/document-combine.js.map +1 -0
- package/lib/framework/document-comment.d.ts +46 -0
- package/lib/framework/document-comment.js +148 -0
- package/lib/framework/document-comment.js.map +1 -0
- package/lib/framework/document-context.d.ts +149 -0
- package/lib/framework/document-context.js +330 -0
- package/lib/framework/document-context.js.map +1 -0
- package/lib/framework/document-eval-func.d.ts +18 -0
- package/lib/framework/document-eval-func.js +48 -0
- package/lib/framework/document-eval-func.js.map +1 -0
- package/lib/framework/document-event.d.ts +213 -0
- package/lib/framework/document-event.js +1054 -0
- package/lib/framework/document-event.js.map +1 -0
- package/lib/framework/document-history.d.ts +26 -0
- package/lib/framework/document-history.js +65 -0
- package/lib/framework/document-history.js.map +1 -0
- package/lib/framework/document-images-loader.d.ts +16 -0
- package/lib/framework/document-images-loader.js +66 -0
- package/lib/framework/document-images-loader.js.map +1 -0
- package/lib/framework/document-input-cursor.d.ts +78 -0
- package/lib/framework/document-input-cursor.js +239 -0
- package/lib/framework/document-input-cursor.js.map +1 -0
- package/lib/framework/document-paint.d.ts +34 -0
- package/lib/framework/document-paint.js +103 -0
- package/lib/framework/document-paint.js.map +1 -0
- package/lib/framework/document-print-offscreen.d.ts +38 -0
- package/lib/framework/document-print-offscreen.js +128 -0
- package/lib/framework/document-print-offscreen.js.map +1 -0
- package/lib/framework/document-print.d.ts +60 -0
- package/lib/framework/document-print.js +203 -0
- package/lib/framework/document-print.js.map +1 -0
- package/lib/framework/document-segmenter.d.ts +2 -0
- package/lib/framework/document-segmenter.js +106 -0
- package/lib/framework/document-segmenter.js.map +1 -0
- package/lib/framework/document-selection.d.ts +89 -0
- package/lib/framework/document-selection.js +358 -0
- package/lib/framework/document-selection.js.map +1 -0
- package/lib/framework/document-template.d.ts +4 -0
- package/lib/framework/document-template.js +20 -0
- package/lib/framework/document-template.js.map +1 -0
- package/lib/framework/document-textline-mode.d.ts +7 -0
- package/lib/framework/document-textline-mode.js +30 -0
- package/lib/framework/document-textline-mode.js.map +1 -0
- package/lib/framework/element-define.d.ts +319 -0
- package/lib/framework/element-define.js +579 -0
- package/lib/framework/element-define.js.map +1 -0
- package/lib/framework/element-event-define.d.ts +99 -0
- package/lib/framework/element-event-define.js +108 -0
- package/lib/framework/element-event-define.js.map +1 -0
- package/lib/framework/element-measure.d.ts +97 -0
- package/lib/framework/element-measure.js +551 -0
- package/lib/framework/element-measure.js.map +1 -0
- package/lib/framework/element-paint.d.ts +42 -0
- package/lib/framework/element-paint.js +170 -0
- package/lib/framework/element-paint.js.map +1 -0
- package/lib/framework/element-props.d.ts +301 -0
- package/lib/framework/element-props.js +809 -0
- package/lib/framework/element-props.js.map +1 -0
- package/lib/framework/element-reader.d.ts +19 -0
- package/lib/framework/element-reader.js +151 -0
- package/lib/framework/element-reader.js.map +1 -0
- package/lib/framework/element-render-cut.d.ts +55 -0
- package/lib/framework/element-render-cut.js +449 -0
- package/lib/framework/element-render-cut.js.map +1 -0
- package/lib/framework/element-serialize.d.ts +30 -0
- package/lib/framework/element-serialize.js +113 -0
- package/lib/framework/element-serialize.js.map +1 -0
- package/lib/framework/element-util.d.ts +369 -0
- package/lib/framework/element-util.js +1463 -0
- package/lib/framework/element-util.js.map +1 -0
- package/lib/framework/impl/checkbox/checkbox-impl.d.ts +24 -0
- package/lib/framework/impl/checkbox/checkbox-impl.js +64 -0
- package/lib/framework/impl/checkbox/checkbox-impl.js.map +1 -0
- package/lib/framework/impl/comments/comment-content-impl.d.ts +40 -0
- package/lib/framework/impl/comments/comment-content-impl.js +105 -0
- package/lib/framework/impl/comments/comment-content-impl.js.map +1 -0
- package/lib/framework/impl/comments/comment-element-impl.d.ts +21 -0
- package/lib/framework/impl/comments/comment-element-impl.js +62 -0
- package/lib/framework/impl/comments/comment-element-impl.js.map +1 -0
- package/lib/framework/impl/comments/comments-container-impl.d.ts +22 -0
- package/lib/framework/impl/comments/comments-container-impl.js +62 -0
- package/lib/framework/impl/comments/comments-container-impl.js.map +1 -0
- package/lib/framework/impl/comments/comments-util.d.ts +12 -0
- package/lib/framework/impl/comments/comments-util.js +67 -0
- package/lib/framework/impl/comments/comments-util.js.map +1 -0
- package/lib/framework/impl/comments/validate-msg-impl.d.ts +21 -0
- package/lib/framework/impl/comments/validate-msg-impl.js +83 -0
- package/lib/framework/impl/comments/validate-msg-impl.js.map +1 -0
- package/lib/framework/impl/data-element/data-decorate-impl.d.ts +30 -0
- package/lib/framework/impl/data-element/data-decorate-impl.js +91 -0
- package/lib/framework/impl/data-element/data-decorate-impl.js.map +1 -0
- package/lib/framework/impl/data-element/data-element-barcode.d.ts +31 -0
- package/lib/framework/impl/data-element/data-element-barcode.js +115 -0
- package/lib/framework/impl/data-element/data-element-barcode.js.map +1 -0
- package/lib/framework/impl/data-element/data-element-base-impl.d.ts +68 -0
- package/lib/framework/impl/data-element/data-element-base-impl.js +205 -0
- package/lib/framework/impl/data-element/data-element-base-impl.js.map +1 -0
- package/lib/framework/impl/data-element/data-element-check-impl.d.ts +35 -0
- package/lib/framework/impl/data-element/data-element-check-impl.js +133 -0
- package/lib/framework/impl/data-element/data-element-check-impl.js.map +1 -0
- package/lib/framework/impl/data-element/data-element-date-impl.d.ts +23 -0
- package/lib/framework/impl/data-element/data-element-date-impl.js +111 -0
- package/lib/framework/impl/data-element/data-element-date-impl.js.map +1 -0
- package/lib/framework/impl/data-element/data-element-group-impl.d.ts +23 -0
- package/lib/framework/impl/data-element/data-element-group-impl.js +130 -0
- package/lib/framework/impl/data-element/data-element-group-impl.js.map +1 -0
- package/lib/framework/impl/data-element/data-element-image-impl.d.ts +30 -0
- package/lib/framework/impl/data-element/data-element-image-impl.js +137 -0
- package/lib/framework/impl/data-element/data-element-image-impl.js.map +1 -0
- package/lib/framework/impl/data-element/data-element-list-impl.d.ts +22 -0
- package/lib/framework/impl/data-element/data-element-list-impl.js +131 -0
- package/lib/framework/impl/data-element/data-element-list-impl.js.map +1 -0
- package/lib/framework/impl/data-element/data-element-text-impl.d.ts +23 -0
- package/lib/framework/impl/data-element/data-element-text-impl.js +103 -0
- package/lib/framework/impl/data-element/data-element-text-impl.js.map +1 -0
- package/lib/framework/impl/decorate/fill-null-space-imple.d.ts +21 -0
- package/lib/framework/impl/decorate/fill-null-space-imple.js +43 -0
- package/lib/framework/impl/decorate/fill-null-space-imple.js.map +1 -0
- package/lib/framework/impl/document/doc-body-impl.d.ts +27 -0
- package/lib/framework/impl/document/doc-body-impl.js +79 -0
- package/lib/framework/impl/document/doc-body-impl.js.map +1 -0
- package/lib/framework/impl/document/doc-body-part-impl.d.ts +30 -0
- package/lib/framework/impl/document/doc-body-part-impl.js +94 -0
- package/lib/framework/impl/document/doc-body-part-impl.js.map +1 -0
- package/lib/framework/impl/document/doc-container-impl.d.ts +16 -0
- package/lib/framework/impl/document/doc-container-impl.js +21 -0
- package/lib/framework/impl/document/doc-container-impl.js.map +1 -0
- package/lib/framework/impl/document/doc-footer-impl.d.ts +26 -0
- package/lib/framework/impl/document/doc-footer-impl.js +77 -0
- package/lib/framework/impl/document/doc-footer-impl.js.map +1 -0
- package/lib/framework/impl/document/doc-header-impl.d.ts +26 -0
- package/lib/framework/impl/document/doc-header-impl.js +83 -0
- package/lib/framework/impl/document/doc-header-impl.js.map +1 -0
- package/lib/framework/impl/document/doc-impl.d.ts +61 -0
- package/lib/framework/impl/document/doc-impl.js +209 -0
- package/lib/framework/impl/document/doc-impl.js.map +1 -0
- package/lib/framework/impl/media-formula/menstrual-history.d.ts +35 -0
- package/lib/framework/impl/media-formula/menstrual-history.js +153 -0
- package/lib/framework/impl/media-formula/menstrual-history.js.map +1 -0
- package/lib/framework/impl/paragraph/p-impl.d.ts +45 -0
- package/lib/framework/impl/paragraph/p-impl.js +156 -0
- package/lib/framework/impl/paragraph/p-impl.js.map +1 -0
- package/lib/framework/impl/picture/image-impl.d.ts +31 -0
- package/lib/framework/impl/picture/image-impl.js +124 -0
- package/lib/framework/impl/picture/image-impl.js.map +1 -0
- package/lib/framework/impl/radio/radio-impl.d.ts +22 -0
- package/lib/framework/impl/radio/radio-impl.js +72 -0
- package/lib/framework/impl/radio/radio-impl.js.map +1 -0
- package/lib/framework/impl/symbol/br-symbol-impl.d.ts +22 -0
- package/lib/framework/impl/symbol/br-symbol-impl.js +54 -0
- package/lib/framework/impl/symbol/br-symbol-impl.js.map +1 -0
- package/lib/framework/impl/symbol/p-symbol-impl.d.ts +19 -0
- package/lib/framework/impl/symbol/p-symbol-impl.js +54 -0
- package/lib/framework/impl/symbol/p-symbol-impl.js.map +1 -0
- package/lib/framework/impl/table/table-cell-impl.d.ts +37 -0
- package/lib/framework/impl/table/table-cell-impl.js +145 -0
- package/lib/framework/impl/table/table-cell-impl.js.map +1 -0
- package/lib/framework/impl/table/table-impl.d.ts +55 -0
- package/lib/framework/impl/table/table-impl.js +363 -0
- package/lib/framework/impl/table/table-impl.js.map +1 -0
- package/lib/framework/impl/table/table-row-impl.d.ts +26 -0
- package/lib/framework/impl/table/table-row-impl.js +75 -0
- package/lib/framework/impl/table/table-row-impl.js.map +1 -0
- package/lib/framework/impl/table/table-split-cell-patch.d.ts +20 -0
- package/lib/framework/impl/table/table-split-cell-patch.js +89 -0
- package/lib/framework/impl/table/table-split-cell-patch.js.map +1 -0
- package/lib/framework/impl/table/table-split-cell.d.ts +90 -0
- package/lib/framework/impl/table/table-split-cell.js +464 -0
- package/lib/framework/impl/table/table-split-cell.js.map +1 -0
- package/lib/framework/impl/table/table-util.d.ts +150 -0
- package/lib/framework/impl/table/table-util.js +678 -0
- package/lib/framework/impl/table/table-util.js.map +1 -0
- package/lib/framework/impl/text/text-impl.d.ts +32 -0
- package/lib/framework/impl/text/text-impl.js +149 -0
- package/lib/framework/impl/text/text-impl.js.map +1 -0
- package/lib/framework/impl/text/track-run-impl.d.ts +27 -0
- package/lib/framework/impl/text/track-run-impl.js +112 -0
- package/lib/framework/impl/text/track-run-impl.js.map +1 -0
- package/lib/framework/notify.d.ts +13 -0
- package/lib/framework/notify.js +116 -0
- package/lib/framework/notify.js.map +1 -0
- package/lib/framework/range-util.d.ts +40 -0
- package/lib/framework/range-util.js +312 -0
- package/lib/framework/range-util.js.map +1 -0
- package/lib/framework/render-context.d.ts +91 -0
- package/lib/framework/render-context.js +384 -0
- package/lib/framework/render-context.js.map +1 -0
- package/lib/framework/render-define.d.ts +109 -0
- package/lib/framework/render-define.js +195 -0
- package/lib/framework/render-define.js.map +1 -0
- package/lib/framework/selection-overlays.d.ts +30 -0
- package/lib/framework/selection-overlays.js +124 -0
- package/lib/framework/selection-overlays.js.map +1 -0
- package/lib/texteditor.d.ts +318 -0
- package/lib/texteditor.js +913 -0
- package/lib/texteditor.js.map +1 -0
- package/lib/util/subject.d.ts +34 -0
- package/lib/util/subject.js +88 -0
- package/lib/util/subject.js.map +1 -0
- package/lib/util/table-bind.d.ts +5 -0
- package/lib/util/table-bind.js +6 -0
- package/lib/util/table-bind.js.map +1 -0
- package/package.json +1 -1
- package/tsconfig.json +1 -1
- package/webpack.config.js +0 -1
@@ -0,0 +1,130 @@
|
|
1
|
+
import { InlineGroupInputElement } from "@/med_editor/framework/impl/data-element/data-element-base-impl";
|
2
|
+
import { InlineGroupRenderObject } from "@/med_editor/framework/render-define";
|
3
|
+
import { ElementFactory } from "@/med_editor/framework/element-define";
|
4
|
+
import { DataElementGroupProps } from "@/med_editor/framework/element-props";
|
5
|
+
import { ElementUtil } from "@/med_editor/framework/element-util";
|
6
|
+
import { ElementSerialize } from "../../element-serialize";
|
7
|
+
import { ParagraphRenderObject } from "../paragraph/p-impl";
|
8
|
+
import { CommonUtil } from "../../common-util";
|
9
|
+
export class DataElementGroupElement extends InlineGroupInputElement {
|
10
|
+
constructor() {
|
11
|
+
super('data-group');
|
12
|
+
this.props = new DataElementGroupProps();
|
13
|
+
this.addEvent('ElementContextMenu', (evt) => {
|
14
|
+
if (evt.ctx.viewOptions.devMode) {
|
15
|
+
evt.menus.push({
|
16
|
+
icon: '获取数据组值', caption: '获取数据组值', eventObj: {
|
17
|
+
onClick: () => {
|
18
|
+
const str = ElementSerialize.serializeString(this, { all: false });
|
19
|
+
alert(str);
|
20
|
+
}
|
21
|
+
}
|
22
|
+
});
|
23
|
+
}
|
24
|
+
}, true);
|
25
|
+
this.addEvent('ElementMousemove', (evt) => {
|
26
|
+
this.isMouseenter = true;
|
27
|
+
this.refreshView();
|
28
|
+
});
|
29
|
+
this.addEvent('ElementMouseLeave', (evt) => {
|
30
|
+
this.isMouseenter = false;
|
31
|
+
this.refreshView();
|
32
|
+
});
|
33
|
+
}
|
34
|
+
clone(data) {
|
35
|
+
const clone = new DataElementGroupElement();
|
36
|
+
this.props.clone(clone.props);
|
37
|
+
if (data) {
|
38
|
+
const length = this.length;
|
39
|
+
for (let i = 0; i < length; i++) {
|
40
|
+
const child = this.getChild(i);
|
41
|
+
if (child !== this.startDecorate && child !== this.endDecorate) {
|
42
|
+
clone.addChild(child.clone(true));
|
43
|
+
}
|
44
|
+
}
|
45
|
+
}
|
46
|
+
return clone;
|
47
|
+
}
|
48
|
+
createRenderObject(options, renderCtx) {
|
49
|
+
return new DataElementGroupRenderObject(this);
|
50
|
+
}
|
51
|
+
serialize(viewOptions) {
|
52
|
+
return {
|
53
|
+
type: this.type,
|
54
|
+
props: {
|
55
|
+
...this.props.getSerializeProps()
|
56
|
+
}
|
57
|
+
};
|
58
|
+
}
|
59
|
+
}
|
60
|
+
export class DataElementGroupRenderObject extends InlineGroupRenderObject {
|
61
|
+
paintPos;
|
62
|
+
beginRender(ctx, position) {
|
63
|
+
//ctx.contentContext.fillRect(position.x, position.y, this.rect.width, this.rect.height, 'yellow');
|
64
|
+
this.paintPos = position;
|
65
|
+
}
|
66
|
+
getCurrentParaGroupRenders() {
|
67
|
+
const renders = [];
|
68
|
+
const currParaRender = ElementUtil.getParentRender(this, ParagraphRenderObject);
|
69
|
+
for (let i = 0; i < this.element.paintRenders.length; i++) {
|
70
|
+
const paraRender = ElementUtil.getParentRender(this.element.paintRenders[i], ParagraphRenderObject);
|
71
|
+
if (paraRender === currParaRender) {
|
72
|
+
renders.push(this.element.paintRenders[i]);
|
73
|
+
}
|
74
|
+
}
|
75
|
+
return renders;
|
76
|
+
}
|
77
|
+
pagePaintCompleted(ctx, position) {
|
78
|
+
const canPaint = this.element.isMouseenter || this.element.isFocused;
|
79
|
+
if (canPaint && this.element.paintRenders.indexOf(this) === 0) {
|
80
|
+
const currParaRenders = this.getCurrentParaGroupRenders();
|
81
|
+
const verOffset = 3;
|
82
|
+
if (currParaRenders.length > 1) {
|
83
|
+
const secondGroupRenderPos = currParaRenders[1].paintPos;
|
84
|
+
if (secondGroupRenderPos.x + currParaRenders[1].rect.width > this.paintPos.x) {
|
85
|
+
const leftPoints = [];
|
86
|
+
const rightPoints = [];
|
87
|
+
for (let i = 0; i < currParaRenders.length; i++) {
|
88
|
+
const groupRender = currParaRenders[i];
|
89
|
+
const groupRenderPos = groupRender.paintPos;
|
90
|
+
leftPoints.push({ x: groupRenderPos.x, y: groupRenderPos.y - verOffset });
|
91
|
+
rightPoints.push({ x: groupRenderPos.x + groupRender.rect.width, y: groupRenderPos.y - verOffset });
|
92
|
+
leftPoints.push({ x: groupRenderPos.x, y: groupRenderPos.y + groupRender.rect.height + verOffset * 2 });
|
93
|
+
rightPoints.push({ x: groupRenderPos.x + groupRender.rect.width, y: groupRenderPos.y + groupRender.rect.height + verOffset * 2 });
|
94
|
+
}
|
95
|
+
const sharpPoints1 = CommonUtil.resharpPoints(rightPoints);
|
96
|
+
const sharpPoints = CommonUtil.resharpPoints([...leftPoints.reverse()]);
|
97
|
+
ctx.overlaysContext.strokeLines([...sharpPoints, ...sharpPoints1, sharpPoints[0]], 1, ctx.viewOptions.dataGroupColor);
|
98
|
+
return;
|
99
|
+
}
|
100
|
+
}
|
101
|
+
for (let i = 0; i < currParaRenders.length; i++) {
|
102
|
+
const render = currParaRenders[i];
|
103
|
+
ctx.overlaysContext.strokeRect(render.paintPos.x, render.paintPos.y - verOffset, render.rect.width, render.rect.height + verOffset * 2, ctx.viewOptions.dataGroupColor);
|
104
|
+
}
|
105
|
+
}
|
106
|
+
}
|
107
|
+
endRender(ctx, position) {
|
108
|
+
}
|
109
|
+
clone() {
|
110
|
+
const cloneRender = new DataElementGroupRenderObject(this.element);
|
111
|
+
cloneRender.rect = ElementUtil.cloneRect(this.rect);
|
112
|
+
for (let i = 0; i < this.length; i++) {
|
113
|
+
cloneRender.addChild(this.getChild(i).clone());
|
114
|
+
}
|
115
|
+
return cloneRender;
|
116
|
+
}
|
117
|
+
}
|
118
|
+
export class DataElementGroupFactory extends ElementFactory {
|
119
|
+
match(type) {
|
120
|
+
return type === "data-group";
|
121
|
+
}
|
122
|
+
createElement(data, renderCtx) {
|
123
|
+
const props = data.props;
|
124
|
+
const ele = new DataElementGroupElement();
|
125
|
+
ele.props.id = props.id;
|
126
|
+
ele.props.name = props.name;
|
127
|
+
return ele;
|
128
|
+
}
|
129
|
+
}
|
130
|
+
//# sourceMappingURL=data-element-group-impl.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"data-element-group-impl.js","sourceRoot":"","sources":["../../../../src/med_editor/framework/impl/data-element/data-element-group-impl.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,30 @@
|
|
1
|
+
import { Element, ElementFactory, ImgLoadStatus, Position, readElementProps, ResizeLeafRenderObject, SerializeProps, ViewOptions } from "@/med_editor/framework/element-define";
|
2
|
+
import { DataEleImageProps } from "@/med_editor/framework/element-props";
|
3
|
+
import { RenderContenxtType } from "@/med_editor/framework/render-context";
|
4
|
+
import { LeafRenderObject, RenderObject } from "@/med_editor/framework/render-define";
|
5
|
+
import { DataElementLeaf } from "./data-element-base-impl";
|
6
|
+
export declare class DataElementImage extends DataElementLeaf<DataEleImageProps> {
|
7
|
+
status: ImgLoadStatus;
|
8
|
+
resizeable: boolean;
|
9
|
+
constructor();
|
10
|
+
createRenderObject(): LeafRenderObject;
|
11
|
+
serialize(options: ViewOptions): SerializeProps;
|
12
|
+
clone(data: boolean): Element;
|
13
|
+
loadImage(ctx: RenderContenxtType): void;
|
14
|
+
destroy(): void;
|
15
|
+
setValue(val: any): void;
|
16
|
+
getValue(): string;
|
17
|
+
}
|
18
|
+
export declare class DataImageRenderObject extends ResizeLeafRenderObject {
|
19
|
+
render(ctx: RenderContenxtType, position: {
|
20
|
+
x: number;
|
21
|
+
y: number;
|
22
|
+
}): void;
|
23
|
+
clone(): RenderObject;
|
24
|
+
pagePaintCompleted(ctx: RenderContenxtType, pos: Position): void;
|
25
|
+
private drawResizeCircle;
|
26
|
+
}
|
27
|
+
export declare class DataElementImgFactory extends ElementFactory<DataEleImageProps> {
|
28
|
+
match(type: string): boolean;
|
29
|
+
createElement(data: readElementProps<DataEleImageProps>, renderCtx: RenderContenxtType): Element;
|
30
|
+
}
|
@@ -0,0 +1,137 @@
|
|
1
|
+
import { ElementFactory, ResizeLeafRenderObject } from "@/med_editor/framework/element-define";
|
2
|
+
import { DataEleImageProps } from "@/med_editor/framework/element-props";
|
3
|
+
import { ElementUtil } from "@/med_editor/framework/element-util";
|
4
|
+
import { DataElementLeaf } from "./data-element-base-impl";
|
5
|
+
export class DataElementImage extends DataElementLeaf {
|
6
|
+
//props: DataEleImageProps;
|
7
|
+
status = 'no';
|
8
|
+
resizeable = true;
|
9
|
+
constructor() {
|
10
|
+
super('data-ele-img');
|
11
|
+
this.props = new DataEleImageProps();
|
12
|
+
//this.addPropValueChangedSub(this.props);
|
13
|
+
this.cursorType = 'move';
|
14
|
+
this.focusable = true;
|
15
|
+
}
|
16
|
+
createRenderObject() {
|
17
|
+
const render = new DataImageRenderObject(this);
|
18
|
+
render.rect.width = this.props.width + 2;
|
19
|
+
render.rect.height = this.props.height + 2;
|
20
|
+
return render;
|
21
|
+
}
|
22
|
+
serialize(options) {
|
23
|
+
return {
|
24
|
+
type: 'data-ele-img',
|
25
|
+
props: {
|
26
|
+
...this.props.getSerializeProps(options)
|
27
|
+
}
|
28
|
+
};
|
29
|
+
}
|
30
|
+
clone(data) {
|
31
|
+
const clone = new DataElementImage();
|
32
|
+
this.props.clone(clone.props);
|
33
|
+
return clone;
|
34
|
+
}
|
35
|
+
loadImage(ctx) {
|
36
|
+
if (this.status === 'no') {
|
37
|
+
this.status = 'loading';
|
38
|
+
const onCallback = (status) => {
|
39
|
+
this.status = status;
|
40
|
+
if (status === 'completed') {
|
41
|
+
this.refreshView();
|
42
|
+
}
|
43
|
+
};
|
44
|
+
ctx.docCtx.imageLoader.loadImage(this.props.src, onCallback);
|
45
|
+
}
|
46
|
+
}
|
47
|
+
destroy() {
|
48
|
+
super.destroy();
|
49
|
+
}
|
50
|
+
setValue(val) {
|
51
|
+
if (this.getValue() === val) {
|
52
|
+
return;
|
53
|
+
}
|
54
|
+
this.props.src = val;
|
55
|
+
}
|
56
|
+
getValue() {
|
57
|
+
return this.props.src;
|
58
|
+
}
|
59
|
+
}
|
60
|
+
export class DataImageRenderObject extends ResizeLeafRenderObject {
|
61
|
+
render(ctx, position) {
|
62
|
+
const dataImgElement = this.element;
|
63
|
+
const picProps = dataImgElement.props;
|
64
|
+
if (dataImgElement.status === 'no') {
|
65
|
+
dataImgElement.loadImage(ctx);
|
66
|
+
return;
|
67
|
+
}
|
68
|
+
if (dataImgElement.status === 'completed') {
|
69
|
+
const imageSource = ctx.docCtx.imageLoader.getImage(picProps.src);
|
70
|
+
if (!imageSource) {
|
71
|
+
return;
|
72
|
+
}
|
73
|
+
if (picProps.border === 'all') {
|
74
|
+
ctx.contentContext.strokeRect(position.x, position.y, this.rect.width, this.rect.height, 'black');
|
75
|
+
}
|
76
|
+
ctx.contentContext.drawImage(imageSource, 0, 0, imageSource.naturalWidth, imageSource.naturalHeight, position.x + 2, position.y + 2, picProps.width, picProps.height);
|
77
|
+
}
|
78
|
+
if (ctx.drawMode === 'view') {
|
79
|
+
let { x, y } = position;
|
80
|
+
const { width, height } = this.rect;
|
81
|
+
const lineWidth = 5;
|
82
|
+
const paintColor = '#0050b3';
|
83
|
+
ctx.contentContext.strokeLines([{ x: x + lineWidth, y }, { x, y }, { x, y: y + height }, { x: x + lineWidth, y: y + height }], 1, paintColor);
|
84
|
+
x = x + width;
|
85
|
+
ctx.contentContext.strokeLines([{ x: x - lineWidth, y }, { x, y }, { x, y: y + height }, { x: x - lineWidth, y: y + height }], 1, paintColor);
|
86
|
+
}
|
87
|
+
}
|
88
|
+
clone() {
|
89
|
+
const clone = new DataImageRenderObject(this.element);
|
90
|
+
clone.rect = ElementUtil.cloneRect(this.rect);
|
91
|
+
return clone;
|
92
|
+
}
|
93
|
+
pagePaintCompleted(ctx, pos) {
|
94
|
+
if (this.element.isFocused) {
|
95
|
+
const { width, height } = this.rect;
|
96
|
+
ctx.contentContext.strokeRect(pos.x, pos.y, this.rect.width, this.rect.height, '#1890ff', 0.5);
|
97
|
+
this.drawResizeCircle(ctx, pos.x, pos.y);
|
98
|
+
this.drawResizeCircle(ctx, pos.x + width, pos.y);
|
99
|
+
this.drawResizeCircle(ctx, pos.x, pos.y + height);
|
100
|
+
this.drawResizeCircle(ctx, pos.x + width, pos.y + height);
|
101
|
+
this.drawResizeCircle(ctx, pos.x + (Math.floor(width / 2)), pos.y);
|
102
|
+
this.drawResizeCircle(ctx, pos.x + (Math.floor(width / 2)), pos.y + height);
|
103
|
+
this.drawResizeCircle(ctx, pos.x, pos.y + (Math.floor(height / 2)));
|
104
|
+
this.drawResizeCircle(ctx, pos.x + width, pos.y + (Math.floor(height / 2)));
|
105
|
+
}
|
106
|
+
}
|
107
|
+
drawResizeCircle(ctx, x, y) {
|
108
|
+
const ctxNative = ctx.contentContext.ctx;
|
109
|
+
ctxNative.save();
|
110
|
+
ctxNative.fillStyle = '#69c0ff';
|
111
|
+
ctxNative.beginPath();
|
112
|
+
ctxNative.arc(x, y, Math.floor(4 / 5 * 4), 0, 2 * Math.PI);
|
113
|
+
ctxNative.closePath();
|
114
|
+
ctxNative.fill();
|
115
|
+
ctxNative.restore();
|
116
|
+
}
|
117
|
+
}
|
118
|
+
export class DataElementImgFactory extends ElementFactory {
|
119
|
+
match(type) {
|
120
|
+
return type === 'data-ele-img';
|
121
|
+
}
|
122
|
+
createElement(data, renderCtx) {
|
123
|
+
const props = data.props;
|
124
|
+
const pic = new DataElementImage();
|
125
|
+
ElementUtil.readEleBaseProps(pic.props, props);
|
126
|
+
//pic.props.id = props.id ?? nanoid(5);
|
127
|
+
//pic.props.name = props.name;
|
128
|
+
//pic.props.caption = props.caption;
|
129
|
+
//pic.props.type = props.type;
|
130
|
+
pic.props.width = props.width;
|
131
|
+
pic.props.height = props.height;
|
132
|
+
pic.props.src = props.src;
|
133
|
+
pic.props.border = props.border || 'all';
|
134
|
+
return pic;
|
135
|
+
}
|
136
|
+
}
|
137
|
+
//# sourceMappingURL=data-element-image-impl.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"data-element-image-impl.js","sourceRoot":"","sources":["../../../../src/med_editor/framework/impl/data-element/data-element-image-impl.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,22 @@
|
|
1
|
+
import { Element, ElementFactory, readElementProps, SerializeProps, ViewOptions } from "@/med_editor/framework/element-define";
|
2
|
+
import { DataEleListProps, DataEleBaseTextProps } from "@/med_editor/framework/element-props";
|
3
|
+
import { RenderContenxtType } from "@/med_editor/framework/render-context";
|
4
|
+
import { RenderObject } from "@/med_editor/framework/render-define";
|
5
|
+
import { DataElementInlineGroup, DataElementRenderObject } from "./data-element-base-impl";
|
6
|
+
export declare class DataElementList extends DataElementInlineGroup<DataEleListProps> {
|
7
|
+
constructor();
|
8
|
+
createRenderObject(): RenderObject;
|
9
|
+
serialize(viewOptions: ViewOptions): SerializeProps & any;
|
10
|
+
clone(data: boolean): DataElementList;
|
11
|
+
setValue(vals: string[]): void;
|
12
|
+
getValue(): string;
|
13
|
+
}
|
14
|
+
export declare class DataElementListRenderObject extends DataElementRenderObject<DataElementList> {
|
15
|
+
constructor(element: DataElementList);
|
16
|
+
clone(): RenderObject;
|
17
|
+
}
|
18
|
+
export declare class DataElementListFactory extends ElementFactory<DataEleListProps> {
|
19
|
+
match(type: string): boolean;
|
20
|
+
createElement(data: readElementProps<DataEleListProps>, renderCtx: RenderContenxtType): Element;
|
21
|
+
createDataEleProps(dest: DataEleListProps, props: DataEleListProps): DataEleBaseTextProps;
|
22
|
+
}
|
@@ -0,0 +1,131 @@
|
|
1
|
+
import { ElementFactory } from "@/med_editor/framework/element-define";
|
2
|
+
import { DataEleListProps } from "@/med_editor/framework/element-props";
|
3
|
+
import { ElementUtil } from "@/med_editor/framework/element-util";
|
4
|
+
import { ElementSerialize } from "../../element-serialize";
|
5
|
+
import { TextGroupElement } from "../text/text-impl";
|
6
|
+
import { DataElementInlineGroup, DataElementRenderObject } from "./data-element-base-impl";
|
7
|
+
export class DataElementList extends DataElementInlineGroup {
|
8
|
+
//props: DataEleListProps;
|
9
|
+
constructor() {
|
10
|
+
super('data-ele-list');
|
11
|
+
this.props = new DataEleListProps();
|
12
|
+
}
|
13
|
+
createRenderObject() {
|
14
|
+
return new DataElementListRenderObject(this);
|
15
|
+
}
|
16
|
+
serialize(viewOptions) {
|
17
|
+
return {
|
18
|
+
type: this.type,
|
19
|
+
props: {
|
20
|
+
...this.props.getSerializeProps(viewOptions)
|
21
|
+
}
|
22
|
+
};
|
23
|
+
}
|
24
|
+
clone(data) {
|
25
|
+
const clone = new DataElementList();
|
26
|
+
this.props.clone(clone.props);
|
27
|
+
if (data) {
|
28
|
+
const length = this.length;
|
29
|
+
for (let i = 0; i < length; i++) {
|
30
|
+
const child = this.getChild(i);
|
31
|
+
if (child !== this.startDecorate && child !== this.endDecorate) {
|
32
|
+
clone.addChild(child.clone(true));
|
33
|
+
}
|
34
|
+
}
|
35
|
+
}
|
36
|
+
return clone;
|
37
|
+
}
|
38
|
+
setValue(vals) {
|
39
|
+
if (this.getValue() === vals.join(';')) {
|
40
|
+
return;
|
41
|
+
}
|
42
|
+
this.pubOnChange('self');
|
43
|
+
this.clearInnerItems();
|
44
|
+
if (this.props.multiSelect) {
|
45
|
+
for (let i = 0; i < vals.length; i++) {
|
46
|
+
const val = vals[i];
|
47
|
+
const option = this.props.options.find(item => item.code === val);
|
48
|
+
if (option) {
|
49
|
+
const valueText = new TextGroupElement();
|
50
|
+
this.props.valueTextProps.clone(valueText.props);
|
51
|
+
const splitSymbol = i < vals.length - 1 ? ';' : '';
|
52
|
+
valueText.text = option.value + splitSymbol;
|
53
|
+
this.addChild(valueText, this.length - 1);
|
54
|
+
}
|
55
|
+
}
|
56
|
+
}
|
57
|
+
else {
|
58
|
+
if (vals.length > 1) {
|
59
|
+
console.warn('当前下拉框是单选模式,不能传入多个值');
|
60
|
+
}
|
61
|
+
const val = vals[0];
|
62
|
+
const option = this.props.options.find(item => item.code === val);
|
63
|
+
if (option) {
|
64
|
+
const valueText = new TextGroupElement();
|
65
|
+
this.props.valueTextProps.clone(valueText.props);
|
66
|
+
valueText.text = option.value;
|
67
|
+
this.addChild(valueText, this.length - 1);
|
68
|
+
}
|
69
|
+
}
|
70
|
+
this.beginMeasure();
|
71
|
+
}
|
72
|
+
getValue() {
|
73
|
+
const values = ElementSerialize.serializeString(this);
|
74
|
+
if (!values) {
|
75
|
+
return '';
|
76
|
+
}
|
77
|
+
const valueItems = values.split(';');
|
78
|
+
const valueCode = [];
|
79
|
+
for (const valueItem of valueItems) {
|
80
|
+
const option = this.props.options.find(item => item.value === valueItem);
|
81
|
+
if (option) {
|
82
|
+
valueCode.push(option.code);
|
83
|
+
}
|
84
|
+
else {
|
85
|
+
valueCode.push(option + '');
|
86
|
+
}
|
87
|
+
}
|
88
|
+
return valueCode.join(';');
|
89
|
+
}
|
90
|
+
}
|
91
|
+
export class DataElementListRenderObject extends DataElementRenderObject {
|
92
|
+
constructor(element) {
|
93
|
+
super(element);
|
94
|
+
}
|
95
|
+
clone() {
|
96
|
+
const cloneRender = new DataElementListRenderObject(this.element);
|
97
|
+
cloneRender.rect = ElementUtil.cloneRect(this.rect);
|
98
|
+
for (let i = 0; i < this.length; i++) {
|
99
|
+
cloneRender.addChild(this.getChild(i).clone());
|
100
|
+
}
|
101
|
+
return cloneRender;
|
102
|
+
}
|
103
|
+
}
|
104
|
+
export class DataElementListFactory extends ElementFactory {
|
105
|
+
match(type) {
|
106
|
+
return type === "data-ele-list";
|
107
|
+
}
|
108
|
+
createElement(data, renderCtx) {
|
109
|
+
const props = data.props;
|
110
|
+
const ele = new DataElementList();
|
111
|
+
this.createDataEleProps(ele.props, props);
|
112
|
+
return ele;
|
113
|
+
}
|
114
|
+
createDataEleProps(dest, props) {
|
115
|
+
const dataEleProps = dest;
|
116
|
+
ElementUtil.readEleBaseProps(dataEleProps, props);
|
117
|
+
//dataEleProps.id = props.id ?? nanoid(5);
|
118
|
+
//dataEleProps.name = props.name;
|
119
|
+
//dataEleProps.caption = props.caption;
|
120
|
+
//dataEleProps.type = props.type;
|
121
|
+
dataEleProps.nullText = props.nullText;
|
122
|
+
dataEleProps.nullTextProps = ElementUtil.readTextProps(null, props.nullTextProps, this.options);
|
123
|
+
dataEleProps.valueTextProps = ElementUtil.readTextProps(null, props.valueTextProps, this.options);
|
124
|
+
const options = props.options || [];
|
125
|
+
dataEleProps.multiSelect = props.multiSelect;
|
126
|
+
dataEleProps.options = [...options];
|
127
|
+
dataEleProps.dropDownStyle = props.dropDownStyle;
|
128
|
+
return dataEleProps;
|
129
|
+
}
|
130
|
+
}
|
131
|
+
//# sourceMappingURL=data-element-list-impl.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"data-element-list-impl.js","sourceRoot":"","sources":["../../../../src/med_editor/framework/impl/data-element/data-element-list-impl.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,23 @@
|
|
1
|
+
import { Element, ElementFactory, SerializeProps, ViewOptions } from "@/med_editor/framework/element-define";
|
2
|
+
import { DataEleBaseTextProps } from "@/med_editor/framework/element-props";
|
3
|
+
import { RenderContenxtType } from "@/med_editor/framework/render-context";
|
4
|
+
import { RenderObject } from "@/med_editor/framework/render-define";
|
5
|
+
import { DataElementInlineGroup, DataElementRenderObject } from "./data-element-base-impl";
|
6
|
+
export declare class DataElementText extends DataElementInlineGroup<DataEleBaseTextProps> {
|
7
|
+
constructor();
|
8
|
+
createRenderObject(): RenderObject;
|
9
|
+
serialize(viewOptions: ViewOptions): SerializeProps & any;
|
10
|
+
clone(data: boolean): DataElementText;
|
11
|
+
setValue(val: string): void;
|
12
|
+
getValue(): string;
|
13
|
+
validate(): string;
|
14
|
+
}
|
15
|
+
export declare class DataElementTextRenderObject extends DataElementRenderObject<DataElementText> {
|
16
|
+
constructor(element: DataElementText);
|
17
|
+
clone(): RenderObject;
|
18
|
+
}
|
19
|
+
export declare class DataElementTextFactory extends ElementFactory<DataEleBaseTextProps> {
|
20
|
+
match(type: string): boolean;
|
21
|
+
createElement(data: any, renderCtx: RenderContenxtType): Element;
|
22
|
+
createDataEleProps(dest: DataEleBaseTextProps, props: DataEleBaseTextProps): DataEleBaseTextProps;
|
23
|
+
}
|
@@ -0,0 +1,103 @@
|
|
1
|
+
import { ElementFactory } from "@/med_editor/framework/element-define";
|
2
|
+
import { DataEleBaseTextProps } from "@/med_editor/framework/element-props";
|
3
|
+
import { ElementUtil } from "@/med_editor/framework/element-util";
|
4
|
+
import { ElementSerialize } from "../../element-serialize";
|
5
|
+
import { TextGroupElement } from "../text/text-impl";
|
6
|
+
import { DataElementInlineGroup, DataElementRenderObject } from "./data-element-base-impl";
|
7
|
+
export class DataElementText extends DataElementInlineGroup {
|
8
|
+
//props: DataEleBaseTextProps;
|
9
|
+
constructor() {
|
10
|
+
super('data-ele-text');
|
11
|
+
this.props = new DataEleBaseTextProps();
|
12
|
+
}
|
13
|
+
createRenderObject() {
|
14
|
+
return new DataElementTextRenderObject(this);
|
15
|
+
}
|
16
|
+
serialize(viewOptions) {
|
17
|
+
return {
|
18
|
+
type: this.type,
|
19
|
+
props: {
|
20
|
+
...this.props.getSerializeProps(viewOptions)
|
21
|
+
}
|
22
|
+
};
|
23
|
+
}
|
24
|
+
clone(data) {
|
25
|
+
const clone = new DataElementText();
|
26
|
+
this.props.clone(clone.props);
|
27
|
+
if (data) {
|
28
|
+
const length = this.length;
|
29
|
+
for (let i = 0; i < length; i++) {
|
30
|
+
const child = this.getChild(i);
|
31
|
+
if (child !== this.startDecorate && child !== this.endDecorate) {
|
32
|
+
clone.addChild(child.clone(true));
|
33
|
+
}
|
34
|
+
}
|
35
|
+
}
|
36
|
+
return clone;
|
37
|
+
}
|
38
|
+
setValue(val) {
|
39
|
+
if (!this.startDecorate) {
|
40
|
+
return;
|
41
|
+
}
|
42
|
+
if (this.getValue() === val) {
|
43
|
+
return;
|
44
|
+
}
|
45
|
+
this.pubOnChange('self');
|
46
|
+
this.clearInnerItems();
|
47
|
+
if (val) {
|
48
|
+
const valueText = new TextGroupElement();
|
49
|
+
this.props.valueTextProps.clone(valueText.props);
|
50
|
+
valueText.text = val;
|
51
|
+
this.addChild(valueText, this.length - 1);
|
52
|
+
}
|
53
|
+
this.beginMeasure();
|
54
|
+
}
|
55
|
+
getValue() {
|
56
|
+
return ElementSerialize.serializeString(this, { all: false });
|
57
|
+
}
|
58
|
+
validate() {
|
59
|
+
let error = super.validate();
|
60
|
+
if (error) {
|
61
|
+
return error;
|
62
|
+
}
|
63
|
+
return '';
|
64
|
+
}
|
65
|
+
}
|
66
|
+
export class DataElementTextRenderObject extends DataElementRenderObject {
|
67
|
+
constructor(element) {
|
68
|
+
super(element);
|
69
|
+
}
|
70
|
+
clone() {
|
71
|
+
const cloneRender = new DataElementTextRenderObject(this.element);
|
72
|
+
cloneRender.rect = ElementUtil.cloneRect(this.rect);
|
73
|
+
for (let i = 0; i < this.length; i++) {
|
74
|
+
cloneRender.addChild(this.getChild(i).clone());
|
75
|
+
}
|
76
|
+
return cloneRender;
|
77
|
+
}
|
78
|
+
}
|
79
|
+
export class DataElementTextFactory extends ElementFactory {
|
80
|
+
match(type) {
|
81
|
+
return type === "data-ele-text";
|
82
|
+
}
|
83
|
+
createElement(data, renderCtx) {
|
84
|
+
const props = data.props;
|
85
|
+
const ele = new DataElementText();
|
86
|
+
this.createDataEleProps(ele.props, props);
|
87
|
+
return ele;
|
88
|
+
}
|
89
|
+
createDataEleProps(dest, props) {
|
90
|
+
const dataEleProps = dest;
|
91
|
+
ElementUtil.readEleBaseProps(dataEleProps, props);
|
92
|
+
//dataEleProps.id = props.id ?? nanoid(5);
|
93
|
+
//dataEleProps.name = props.name;
|
94
|
+
//dataEleProps.caption = props.caption;
|
95
|
+
//dataEleProps.type = props.type;
|
96
|
+
dataEleProps.nullText = props.nullText;
|
97
|
+
dataEleProps.nullTextProps = ElementUtil.readTextProps(null, props.nullTextProps, this.options);
|
98
|
+
dataEleProps.valueTextProps = ElementUtil.readTextProps(null, props.valueTextProps, this.options);
|
99
|
+
dataEleProps.dataType = props.dataType;
|
100
|
+
return dataEleProps;
|
101
|
+
}
|
102
|
+
}
|
103
|
+
//# sourceMappingURL=data-element-text-impl.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"data-element-text-impl.js","sourceRoot":"","sources":["../../../../src/med_editor/framework/impl/data-element/data-element-text-impl.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,21 @@
|
|
1
|
+
import { Element, LeafElement, SerializeProps, ViewOptions } from "../../element-define";
|
2
|
+
import { RenderContenxtType } from "../../render-context";
|
3
|
+
import { LeafRenderObject, RenderObject } from "../../render-define";
|
4
|
+
/**
|
5
|
+
* 当前数据元内容长度小于最小长度时,需要当前元素撑开以达到最小长度
|
6
|
+
*/
|
7
|
+
export declare class FillNullSpaceElement extends LeafElement {
|
8
|
+
length: number;
|
9
|
+
constructor();
|
10
|
+
createRenderObject(options: ViewOptions, renderCtx: RenderContenxtType): RenderObject;
|
11
|
+
serialize(viewOptions: ViewOptions): SerializeProps;
|
12
|
+
clone(data: boolean): Element;
|
13
|
+
}
|
14
|
+
export declare class FillNullSpaceRenderObject extends LeafRenderObject {
|
15
|
+
constructor();
|
16
|
+
render(ctx: RenderContenxtType, position: {
|
17
|
+
x: number;
|
18
|
+
y: number;
|
19
|
+
}): void;
|
20
|
+
clone(): RenderObject;
|
21
|
+
}
|