@talrace/ngx-noder 0.0.8 → 0.0.9
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/esm2022/lib/apart-components/add-link-dialog/add-link-dialog.component.mjs +15 -9
- package/esm2022/lib/apart-components/editor-toolbar/components/base-toolbar.component.mjs +8 -2
- package/esm2022/lib/apart-components/editor-toolbar/components/buttons/font/font.component.mjs +2 -2
- package/esm2022/lib/apart-components/editor-toolbar/components/buttons/font-size/font-size.component.mjs +3 -3
- package/esm2022/lib/apart-components/editor-toolbar/shared/toolbar-styles.helper.mjs +1 -8
- package/esm2022/lib/editor/components/edges/edge.component.mjs +2 -2
- package/esm2022/lib/editor/components/edges/edges.mjs +21 -2
- package/esm2022/lib/editor/components/image/input-handler/image-input.handler.mjs +18 -1
- package/esm2022/lib/editor/components/shared/services/custom-content.service.mjs +22 -56
- package/esm2022/lib/editor/components/table/components/table-cell.component.mjs +6 -6
- package/esm2022/lib/editor/components/table/components/table.component.mjs +13 -4
- package/esm2022/lib/editor/components/table/models/cell-data.model.mjs +3 -4
- package/esm2022/lib/editor/components/table/selection/table-selection.mjs +15 -5
- package/esm2022/lib/editor/content/constants/editor.const.mjs +9 -1
- package/esm2022/lib/editor/content/display-data/display-data.mjs +839 -0
- package/esm2022/lib/editor/content/display-data/general-properties.model.mjs +1 -1
- package/esm2022/lib/editor/content/display-data/models/paragraph-info.model.mjs +8 -0
- package/esm2022/lib/editor/content/display-data/paragraph.mjs +5 -1
- package/esm2022/lib/editor/content/display-data/text-line-info.mjs +2 -1
- package/esm2022/lib/editor/content/display-data/toolbar-styles.interface.mjs +1 -1
- package/esm2022/lib/editor/content/helpers/content-style.helper.mjs +12 -30
- package/esm2022/lib/editor/content/helpers/display-token.helper.mjs +62 -0
- package/esm2022/lib/editor/display/layers/cursor.layer.mjs +9 -8
- package/esm2022/lib/editor/display/layers/pages.layer.mjs +5 -5
- package/esm2022/lib/editor/display/layers/print.text.layer.mjs +2 -2
- package/esm2022/lib/editor/display/layers/selection.layer.mjs +15 -9
- package/esm2022/lib/editor/display/layers/text.layer.mjs +25 -27
- package/esm2022/lib/editor/display/print/print.renderer.mjs +8 -8
- package/esm2022/lib/editor/display/renderer.mjs +10 -10
- package/esm2022/lib/editor/display/rendering.helper.mjs +2 -4
- package/esm2022/lib/editor/display/virtual.renderer.mjs +5 -5
- package/esm2022/lib/editor/execution/edit.session.mjs +199 -755
- package/esm2022/lib/editor/execution/editor.mjs +116 -75
- package/esm2022/lib/editor/execution/helpers/format-style.helper.mjs +1 -33
- package/esm2022/lib/editor/execution/helpers/image.helpet.mjs +12 -0
- package/esm2022/lib/editor/execution/helpers/paragraph.helper.mjs +11 -3
- package/esm2022/lib/editor/execution/regulator.service.mjs +28 -20
- package/esm2022/lib/editor/gadgets/numbering/numbering-paragraph-style.model.mjs +13 -0
- package/esm2022/lib/editor/gadgets/numbering/numbering.helper.mjs +77 -10
- package/esm2022/lib/editor/gadgets/search/search.mjs +6 -6
- package/esm2022/lib/editor/interaction/editor.service.mjs +27 -6
- package/esm2022/lib/editor/interaction/input.handler.mjs +8 -5
- package/esm2022/lib/editor/interaction/mouse.handler.mjs +2 -1
- package/esm2022/lib/editor/operations/helpers/format-operations.helper.mjs +32 -2
- package/esm2022/lib/editor/operations/helpers/link-operations.helper.mjs +47 -12
- package/esm2022/lib/editor/operations/operations-helper.helper.mjs +13 -14
- package/esm2022/lib/editor/operations/save-commands.helper.mjs +2 -2
- package/esm2022/lib/editor/positioning/content.helper.mjs +15 -15
- package/esm2022/lib/editor/positioning/line-width.helper.mjs +5 -5
- package/esm2022/lib/editor/positioning/position.helper.mjs +34 -32
- package/esm2022/lib/editor/positioning/selection.mjs +42 -32
- package/esm2022/lib/editor/revision.helper.mjs +4 -3
- package/fesm2022/talrace-ngx-noder.mjs +3765 -3548
- package/fesm2022/talrace-ngx-noder.mjs.map +1 -1
- package/lib/apart-components/add-link-dialog/add-link-dialog.component.d.ts +0 -1
- package/lib/apart-components/editor-toolbar/shared/toolbar-styles.helper.d.ts +0 -2
- package/lib/editor/components/image/input-handler/image-input.handler.d.ts +3 -0
- package/lib/editor/components/shared/services/custom-content.service.d.ts +3 -5
- package/lib/editor/components/table/components/table-cell.component.d.ts +1 -1
- package/lib/editor/components/table/components/table.component.d.ts +1 -0
- package/lib/editor/components/table/models/cell-data.model.d.ts +1 -1
- package/lib/editor/components/table/selection/table-selection.d.ts +2 -0
- package/lib/editor/content/constants/editor.const.d.ts +2 -0
- package/lib/editor/content/display-data/display-data.d.ts +103 -0
- package/lib/editor/content/display-data/general-properties.model.d.ts +5 -0
- package/lib/editor/content/display-data/models/paragraph-info.model.d.ts +9 -0
- package/lib/editor/content/display-data/paragraph.d.ts +1 -0
- package/lib/editor/content/display-data/text-line-info.d.ts +1 -0
- package/lib/editor/content/display-data/toolbar-styles.interface.d.ts +1 -1
- package/lib/editor/content/helpers/content-style.helper.d.ts +1 -2
- package/lib/editor/content/helpers/display-token.helper.d.ts +6 -0
- package/lib/editor/display/layers/text.layer.d.ts +1 -2
- package/lib/editor/display/print/print.renderer.d.ts +0 -2
- package/lib/editor/execution/edit.session.d.ts +11 -59
- package/lib/editor/execution/editor.d.ts +9 -6
- package/lib/editor/execution/helpers/format-style.helper.d.ts +0 -2
- package/lib/editor/execution/helpers/image.helpet.d.ts +4 -0
- package/lib/editor/execution/regulator.service.d.ts +1 -1
- package/lib/editor/gadgets/numbering/numbering-paragraph-style.model.d.ts +6 -0
- package/lib/editor/gadgets/numbering/numbering.helper.d.ts +10 -3
- package/lib/editor/interaction/editor.service.d.ts +12 -3
- package/lib/editor/operations/helpers/link-operations.helper.d.ts +5 -3
- package/lib/editor/positioning/content.helper.d.ts +6 -5
- package/lib/editor/positioning/position.helper.d.ts +3 -3
- package/lib/editor/positioning/selection.d.ts +3 -0
- package/package.json +1 -1
- package/src/_ngx-noder.theme.scss +31 -2
- package/esm2022/lib/editor/content/display-data/document.mjs +0 -134
- package/esm2022/lib/editor/content/display-data/pages.wrap.mjs +0 -226
- package/esm2022/lib/editor/execution/helpers/delta.helper.mjs +0 -18
- package/lib/editor/content/display-data/document.d.ts +0 -56
- package/lib/editor/content/display-data/pages.wrap.d.ts +0 -42
- package/lib/editor/execution/helpers/delta.helper.d.ts +0 -6
|
@@ -3,12 +3,15 @@ export class ImageInputHandler {
|
|
|
3
3
|
constructor(editorService, image) {
|
|
4
4
|
this.editorService = editorService;
|
|
5
5
|
this.image = image;
|
|
6
|
+
this.imageComponentTagName = 'APP-NOD-IMAGE';
|
|
6
7
|
this.undoRedoActions = {};
|
|
7
8
|
this.imageKeyDownSubscription = fromEvent(document, 'keydown').subscribe(event => this.onKeyDown(event));
|
|
9
|
+
this.clickSubscription = fromEvent(document, 'click').subscribe(event => this.onClick(event.target));
|
|
8
10
|
this.fillUndoRedoActions();
|
|
9
11
|
}
|
|
10
12
|
destroy() {
|
|
11
13
|
this.imageKeyDownSubscription?.unsubscribe();
|
|
14
|
+
this.clickSubscription?.unsubscribe();
|
|
12
15
|
}
|
|
13
16
|
onKeyDown(event) {
|
|
14
17
|
if (this.editorService.isViewOnly) {
|
|
@@ -22,6 +25,10 @@ export class ImageInputHandler {
|
|
|
22
25
|
if (this.undoRedoActions[keyCombination] && !this.editorService.isViewOnly) {
|
|
23
26
|
this.undoRedoActions[keyCombination]();
|
|
24
27
|
event.preventDefault();
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
if (!event.ctrlKey && !event.altKey && !event.shiftKey && !event.metaKey && event.key.length === 1) {
|
|
31
|
+
this.editorService.insertText(event.key);
|
|
25
32
|
}
|
|
26
33
|
}
|
|
27
34
|
getKeyCombination(event) {
|
|
@@ -34,5 +41,15 @@ export class ImageInputHandler {
|
|
|
34
41
|
this.undoRedoActions['Ctrl-KeyY'] = () => this.editorService.redo();
|
|
35
42
|
this.undoRedoActions['Command-KeyY'] = () => this.editorService.redo();
|
|
36
43
|
}
|
|
44
|
+
onClick(element) {
|
|
45
|
+
let currentElement = element;
|
|
46
|
+
while (currentElement) {
|
|
47
|
+
if (currentElement.tagName === this.imageComponentTagName) {
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
currentElement = currentElement.parentElement;
|
|
51
|
+
}
|
|
52
|
+
this.editorService.blurCustomComponent();
|
|
53
|
+
}
|
|
37
54
|
}
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UtaW5wdXQuaGFuZGxlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1ub2Rlci9zcmMvbGliL2VkaXRvci9jb21wb25lbnRzL2ltYWdlL2lucHV0LWhhbmRsZXIvaW1hZ2UtaW5wdXQuaGFuZGxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFnQixNQUFNLE1BQU0sQ0FBQztBQUsvQyxNQUFNLE9BQU8saUJBQWlCO0lBUzFCLFlBQTZCLGFBQTRCLEVBQW1CLEtBQTBCO1FBQXpFLGtCQUFhLEdBQWIsYUFBYSxDQUFlO1FBQW1CLFVBQUssR0FBTCxLQUFLLENBQXFCO1FBUjdGLDBCQUFxQixHQUFHLGVBQWUsQ0FBQztRQUVoQyxvQkFBZSxHQUFrQyxFQUFFLENBQUM7UUFPakUsSUFBSSxDQUFDLHdCQUF3QixHQUFHLFNBQVMsQ0FBZ0IsUUFBUSxFQUFFLFNBQVMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztRQUN4SCxJQUFJLENBQUMsaUJBQWlCLEdBQUcsU0FBUyxDQUFnQixRQUFRLEVBQUUsT0FBTyxDQUFDLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsTUFBcUIsQ0FBQyxDQUFDLENBQUM7UUFDbkksSUFBSSxDQUFDLG1CQUFtQixFQUFFLENBQUM7SUFDL0IsQ0FBQztJQUVELE9BQU87UUFDSCxJQUFJLENBQUMsd0JBQXdCLEVBQUUsV0FBVyxFQUFFLENBQUM7UUFDN0MsSUFBSSxDQUFDLGlCQUFpQixFQUFFLFdBQVcsRUFBRSxDQUFDO0lBQzFDLENBQUM7SUFFTyxTQUFTLENBQUMsS0FBb0I7UUFDbEMsSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDLFVBQVUsRUFBRTtZQUMvQixPQUFPO1NBQ1Y7UUFFRCxJQUFJLENBQUMsV0FBVyxFQUFFLFFBQVEsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDOUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQztZQUN2RCxPQUFPO1NBQ1Y7UUFFRCxNQUFNLGNBQWMsR0FBRyxJQUFJLENBQUMsaUJBQWlCLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDckQsSUFBSSxJQUFJLENBQUMsZUFBZSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxVQUFVLEVBQUU7WUFDeEUsSUFBSSxDQUFDLGVBQWUsQ0FBQyxjQUFjLENBQUMsRUFBRSxDQUFDO1lBQ3ZDLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztZQUN2QixPQUFPO1NBQ1Y7UUFFRCxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sSUFBSSxLQUFLLENBQUMsR0FBRyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7WUFDaEcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1NBQzVDO0lBQ0wsQ0FBQztJQUVPLGlCQUFpQixDQUFDLEtBQW9CO1FBQzFDLElBQUksTUFBTSxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBQzdDLE9BQU8sS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsR0FBRyxNQUFNLFFBQVEsS0FBSyxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7SUFDOUQsQ0FBQztJQUVPLG1CQUFtQjtRQUN2QixJQUFJLENBQUMsZUFBZSxDQUFDLFdBQVcsQ0FBQyxHQUFHLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDcEUsSUFBSSxDQUFDLGVBQWUsQ0FBQyxjQUFjLENBQUMsR0FBRyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3ZFLElBQUksQ0FBQyxlQUFlLENBQUMsV0FBVyxDQUFDLEdBQUcsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUNwRSxJQUFJLENBQUMsZUFBZSxDQUFDLGNBQWMsQ0FBQyxHQUFHLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDM0UsQ0FBQztJQUVPLE9BQU8sQ0FBQyxPQUFvQjtRQUNoQyxJQUFJLGNBQWMsR0FBRyxPQUFPLENBQUM7UUFDN0IsT0FBTyxjQUFjLEVBQUU7WUFDbkIsSUFBSSxjQUFjLENBQUMsT0FBTyxLQUFLLElBQUksQ0FBQyxxQkFBcUIsRUFBRTtnQkFDdkQsT0FBTzthQUNWO1lBQ0QsY0FBYyxHQUFHLGNBQWMsQ0FBQyxhQUFhLENBQUM7U0FDakQ7UUFDRCxJQUFJLENBQUMsYUFBYSxDQUFDLG1CQUFtQixFQUFFLENBQUM7SUFDN0MsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZnJvbUV2ZW50LCBTdWJzY3JpcHRpb24gfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHsgRWRpdG9yU2VydmljZSB9IGZyb20gJy4uLy4uLy4uL2ludGVyYWN0aW9uL2VkaXRvci5zZXJ2aWNlJztcbmltcG9ydCB7IE5vZGVySW1hZ2VDb21wb25lbnQgfSBmcm9tICcuLi9jb21wb25lbnRzL2ltYWdlLmNvbXBvbmVudCc7XG5cbmV4cG9ydCBjbGFzcyBJbWFnZUlucHV0SGFuZGxlciB7XG4gICAgcmVhZG9ubHkgaW1hZ2VDb21wb25lbnRUYWdOYW1lID0gJ0FQUC1OT0QtSU1BR0UnO1xuXG4gICAgcHJpdmF0ZSByZWFkb25seSB1bmRvUmVkb0FjdGlvbnM6IHsgW2tleTogc3RyaW5nXTogKCkgPT4gdm9pZCB9ID0ge307XG5cbiAgICBwcml2YXRlIHJlYWRvbmx5IGltYWdlS2V5RG93blN1YnNjcmlwdGlvbjogU3Vic2NyaXB0aW9uO1xuXG4gICAgcHJpdmF0ZSByZWFkb25seSBjbGlja1N1YnNjcmlwdGlvbjogU3Vic2NyaXB0aW9uO1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBlZGl0b3JTZXJ2aWNlOiBFZGl0b3JTZXJ2aWNlLCBwcml2YXRlIHJlYWRvbmx5IGltYWdlOiBOb2RlckltYWdlQ29tcG9uZW50KSB7XG4gICAgICAgIHRoaXMuaW1hZ2VLZXlEb3duU3Vic2NyaXB0aW9uID0gZnJvbUV2ZW50PEtleWJvYXJkRXZlbnQ+KGRvY3VtZW50LCAna2V5ZG93bicpLnN1YnNjcmliZShldmVudCA9PiB0aGlzLm9uS2V5RG93bihldmVudCkpO1xuICAgICAgICB0aGlzLmNsaWNrU3Vic2NyaXB0aW9uID0gZnJvbUV2ZW50PEtleWJvYXJkRXZlbnQ+KGRvY3VtZW50LCAnY2xpY2snKS5zdWJzY3JpYmUoZXZlbnQgPT4gdGhpcy5vbkNsaWNrKGV2ZW50LnRhcmdldCBhcyBIVE1MRWxlbWVudCkpO1xuICAgICAgICB0aGlzLmZpbGxVbmRvUmVkb0FjdGlvbnMoKTtcbiAgICB9XG5cbiAgICBkZXN0cm95KCk6IHZvaWQge1xuICAgICAgICB0aGlzLmltYWdlS2V5RG93blN1YnNjcmlwdGlvbj8udW5zdWJzY3JpYmUoKTtcbiAgICAgICAgdGhpcy5jbGlja1N1YnNjcmlwdGlvbj8udW5zdWJzY3JpYmUoKTtcbiAgICB9XG5cbiAgICBwcml2YXRlIG9uS2V5RG93bihldmVudDogS2V5Ym9hcmRFdmVudCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5lZGl0b3JTZXJ2aWNlLmlzVmlld09ubHkpIHtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChbJ0JhY2tzcGFjZScsICdEZWxldGUnXS5pbmNsdWRlcyhldmVudC5jb2RlKSkge1xuICAgICAgICAgICAgdGhpcy5lZGl0b3JTZXJ2aWNlLnJlbW92ZUltYWdlKHRoaXMuaW1hZ2UuaW5zZXJ0SW5kZXgpO1xuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3Qga2V5Q29tYmluYXRpb24gPSB0aGlzLmdldEtleUNvbWJpbmF0aW9uKGV2ZW50KTtcbiAgICAgICAgaWYgKHRoaXMudW5kb1JlZG9BY3Rpb25zW2tleUNvbWJpbmF0aW9uXSAmJiAhdGhpcy5lZGl0b3JTZXJ2aWNlLmlzVmlld09ubHkpIHtcbiAgICAgICAgICAgIHRoaXMudW5kb1JlZG9BY3Rpb25zW2tleUNvbWJpbmF0aW9uXSgpO1xuICAgICAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmICghZXZlbnQuY3RybEtleSAmJiAhZXZlbnQuYWx0S2V5ICYmICFldmVudC5zaGlmdEtleSAmJiAhZXZlbnQubWV0YUtleSAmJiBldmVudC5rZXkubGVuZ3RoID09PSAxKSB7XG4gICAgICAgICAgICB0aGlzLmVkaXRvclNlcnZpY2UuaW5zZXJ0VGV4dChldmVudC5rZXkpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBnZXRLZXlDb21iaW5hdGlvbihldmVudDogS2V5Ym9hcmRFdmVudCk6IHN0cmluZyB7XG4gICAgICAgIGxldCByZXN1bHQgPSBldmVudC5tZXRhS2V5ID8gJ0NvbW1hbmQtJyA6ICcnO1xuICAgICAgICByZXR1cm4gZXZlbnQuY3RybEtleSA/IGAke3Jlc3VsdH1DdHJsLSR7ZXZlbnQuY29kZX1gIDogJyc7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBmaWxsVW5kb1JlZG9BY3Rpb25zKCk6IHZvaWQge1xuICAgICAgICB0aGlzLnVuZG9SZWRvQWN0aW9uc1snQ3RybC1LZXlaJ10gPSAoKSA9PiB0aGlzLmVkaXRvclNlcnZpY2UudW5kbygpO1xuICAgICAgICB0aGlzLnVuZG9SZWRvQWN0aW9uc1snQ29tbWFuZC1LZXlaJ10gPSAoKSA9PiB0aGlzLmVkaXRvclNlcnZpY2UudW5kbygpO1xuICAgICAgICB0aGlzLnVuZG9SZWRvQWN0aW9uc1snQ3RybC1LZXlZJ10gPSAoKSA9PiB0aGlzLmVkaXRvclNlcnZpY2UucmVkbygpO1xuICAgICAgICB0aGlzLnVuZG9SZWRvQWN0aW9uc1snQ29tbWFuZC1LZXlZJ10gPSAoKSA9PiB0aGlzLmVkaXRvclNlcnZpY2UucmVkbygpO1xuICAgIH1cblxuICAgIHByaXZhdGUgb25DbGljayhlbGVtZW50OiBIVE1MRWxlbWVudCk6IHZvaWQge1xuICAgICAgICBsZXQgY3VycmVudEVsZW1lbnQgPSBlbGVtZW50O1xuICAgICAgICB3aGlsZSAoY3VycmVudEVsZW1lbnQpIHtcbiAgICAgICAgICAgIGlmIChjdXJyZW50RWxlbWVudC50YWdOYW1lID09PSB0aGlzLmltYWdlQ29tcG9uZW50VGFnTmFtZSkge1xuICAgICAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGN1cnJlbnRFbGVtZW50ID0gY3VycmVudEVsZW1lbnQucGFyZW50RWxlbWVudDtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLmVkaXRvclNlcnZpY2UuYmx1ckN1c3RvbUNvbXBvbmVudCgpO1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -2,8 +2,6 @@ import { Injectable } from '@angular/core';
|
|
|
2
2
|
import { CUSTOM_ELEMENT_MARKER, TABLE_MARKER } from '../custom-content-markers.const';
|
|
3
3
|
import { DEFAULT_PARAGRAPH_STYLE } from '../../../content/constants/editor.const';
|
|
4
4
|
import { DisplayToken } from '../../../content/display-data/display-token.model';
|
|
5
|
-
import { DocxModel } from '../../../../models/generated/docx.model';
|
|
6
|
-
import { Edges } from '../../edges/edges';
|
|
7
5
|
import { EXTERNAL_ELEMENT_SERVICE } from '../../external-element/external-elements.const';
|
|
8
6
|
import { NoderImageComponent } from '../../image/components/image.component';
|
|
9
7
|
import { NoderTabComponent } from '../../tab/tab.component';
|
|
@@ -16,51 +14,34 @@ export class CustomContentService {
|
|
|
16
14
|
this.injector = injector;
|
|
17
15
|
this.elements = this.injector.get(EXTERNAL_ELEMENT_SERVICE).elements;
|
|
18
16
|
}
|
|
19
|
-
|
|
20
|
-
const contentWidth = document.pageWidth - (document.pageMargin.left + document.pageMargin.right);
|
|
21
|
-
return {
|
|
22
|
-
images: this.componentService.generateComponents(NoderImageComponent, model?.images || [], x => {
|
|
23
|
-
return { image: x, sessionId, generalProperties };
|
|
24
|
-
}),
|
|
25
|
-
tables: this.componentService.generateComponents(NoderTableComponent, model?.tables || [], x => {
|
|
26
|
-
return { table: x, sessionId, generalProperties };
|
|
27
|
-
}),
|
|
28
|
-
tabs: this.componentService.generateComponents(NoderTabComponent, model?.tabs || [], x => {
|
|
29
|
-
return { tab: x, sessionId, generalProperties };
|
|
30
|
-
}),
|
|
31
|
-
customElements: this.generateElementComponents(model?.elements || [], sessionId, contentWidth),
|
|
32
|
-
edges: model instanceof DocxModel
|
|
33
|
-
? new Edges(this.componentService, model.headers, model.footers, document.pageMargin, document.pageWidth, sessionId, generalProperties)
|
|
34
|
-
: null
|
|
35
|
-
};
|
|
36
|
-
}
|
|
37
|
-
getOrGenerateComponent(model, components, sessionId, generalProperties, contentWidth, charIndex, char) {
|
|
38
|
-
if (char !== CUSTOM_ELEMENT_MARKER && char !== TABLE_MARKER) {
|
|
39
|
-
return null;
|
|
40
|
-
}
|
|
41
|
-
const component = this.getComponent(components, char, charIndex);
|
|
42
|
-
if (component) {
|
|
43
|
-
return component;
|
|
44
|
-
}
|
|
17
|
+
generateComponent(model, components, sessionId, generalProperties, contentWidth, charIndex) {
|
|
45
18
|
const image = model.images.find(x => x.insertIndex === charIndex);
|
|
46
19
|
if (image) {
|
|
47
|
-
|
|
20
|
+
const component = this.componentService.generateComponent(NoderImageComponent, { image, sessionId, generalProperties });
|
|
21
|
+
components.images.push(component);
|
|
22
|
+
return component;
|
|
48
23
|
}
|
|
49
24
|
const table = model.tables.find(x => x.insertIndex === charIndex);
|
|
50
25
|
if (table) {
|
|
51
|
-
|
|
26
|
+
const component = this.componentService.generateComponent(NoderTableComponent, { table, sessionId, generalProperties });
|
|
27
|
+
components.tables.push(component);
|
|
28
|
+
return component;
|
|
52
29
|
}
|
|
53
30
|
const tab = model.tabs.find(x => x.insertIndex === charIndex);
|
|
54
31
|
if (tab) {
|
|
55
|
-
|
|
32
|
+
const component = this.componentService.generateComponent(NoderTabComponent, { tab, sessionId, generalProperties });
|
|
33
|
+
components.tabs.push(component);
|
|
34
|
+
return component;
|
|
56
35
|
}
|
|
57
|
-
const
|
|
58
|
-
if (
|
|
59
|
-
|
|
60
|
-
content
|
|
36
|
+
const content = model.elements.find(x => x.insertIndex === charIndex);
|
|
37
|
+
if (content) {
|
|
38
|
+
const component = this.componentService.generateComponent(this.findComponentType(content.type), {
|
|
39
|
+
content,
|
|
61
40
|
sessionId,
|
|
62
41
|
contentWidth
|
|
63
42
|
});
|
|
43
|
+
components.customElements.push(component);
|
|
44
|
+
return component;
|
|
64
45
|
}
|
|
65
46
|
return null;
|
|
66
47
|
}
|
|
@@ -70,24 +51,6 @@ export class CustomContentService {
|
|
|
70
51
|
return this.componentService.generateComponent(type, { content: x, sessionId, contentWidth });
|
|
71
52
|
});
|
|
72
53
|
}
|
|
73
|
-
addToCustomComponents(components, component, char, charIndex) {
|
|
74
|
-
const existed = this.getComponent(components, char, charIndex);
|
|
75
|
-
if (existed) {
|
|
76
|
-
return;
|
|
77
|
-
}
|
|
78
|
-
if (component.componentType === NoderImageComponent) {
|
|
79
|
-
components.images.push(component);
|
|
80
|
-
}
|
|
81
|
-
else if (component.componentType === NoderTableComponent) {
|
|
82
|
-
components.tables.push(component);
|
|
83
|
-
}
|
|
84
|
-
else if (component.componentType === NoderTabComponent) {
|
|
85
|
-
components.tabs.push(component);
|
|
86
|
-
}
|
|
87
|
-
else {
|
|
88
|
-
components.customElements.push(component);
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
54
|
isFragmentContainComponent(components, textFragment, fragmentDistance) {
|
|
92
55
|
if (textFragment.includes(CUSTOM_ELEMENT_MARKER)) {
|
|
93
56
|
return (this.isFragmentContainComponents(components.images, fragmentDistance) ||
|
|
@@ -148,11 +111,14 @@ export class CustomContentService {
|
|
|
148
111
|
findComponentType(type) {
|
|
149
112
|
return this.elements.find(x => x.type === type).componentType;
|
|
150
113
|
}
|
|
114
|
+
findComponent(components, insertIndex) {
|
|
115
|
+
return components.find((x) => x.instance.insertIndex === insertIndex);
|
|
116
|
+
}
|
|
151
117
|
isFragmentContainComponents(components, distance) {
|
|
152
118
|
return components.some(x => x.instance.insertIndex >= distance.start && x.instance.insertIndex <= distance.end);
|
|
153
119
|
}
|
|
154
|
-
|
|
155
|
-
return
|
|
120
|
+
isSpecialMarker(char) {
|
|
121
|
+
return char === CUSTOM_ELEMENT_MARKER || char === TABLE_MARKER;
|
|
156
122
|
}
|
|
157
123
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomContentService, deps: [{ token: i1.ComponentService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
158
124
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomContentService }); }
|
|
@@ -160,4 +126,4 @@ export class CustomContentService {
|
|
|
160
126
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomContentService, decorators: [{
|
|
161
127
|
type: Injectable
|
|
162
128
|
}], ctorParameters: () => [{ type: i1.ComponentService }, { type: i0.Injector }] });
|
|
163
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-content.service.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-noder/src/lib/editor/components/shared/services/custom-content.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,UAAU,EAAkB,MAAM,eAAe,CAAC;AAKzE,OAAO,EAAE,qBAAqB,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AACtF,OAAO,EAAE,uBAAuB,EAAE,MAAM,yCAAyC,CAAC;AAClF,OAAO,EAAE,YAAY,EAAE,MAAM,mDAAmD,CAAC;AAGjF,OAAO,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AACpE,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAE1C,OAAO,EAAE,wBAAwB,EAAE,MAAM,gDAAgD,CAAC;AAM1F,OAAO,EAAE,mBAAmB,EAAE,MAAM,wCAAwC,CAAC;AAC7E,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAC5D,OAAO,EAAE,mBAAmB,EAAE,MAAM,wCAAwC,CAAC;;;AAG7E,MAAM,OAAO,oBAAoB;IAG7B,YAAmB,gBAAkC,EAAU,QAAkB;QAA9D,qBAAgB,GAAhB,gBAAgB,CAAkB;QAAU,aAAQ,GAAR,QAAQ,CAAU;QAC7E,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAC,QAAQ,CAAC;IACzE,CAAC;IAED,kBAAkB,CACd,KAAwB,EACxB,SAAiB,EACjB,iBAAyC,EACzC,QAAkB;QAElB,MAAM,YAAY,GAAG,QAAQ,CAAC,SAAS,GAAG,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,GAAG,QAAQ,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACjG,OAAO;YACH,MAAM,EAAE,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,mBAAmB,EAAE,KAAK,EAAE,MAAM,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE;gBAC3F,OAAO,EAAE,KAAK,EAAE,CAAC,EAAE,SAAS,EAAE,iBAAiB,EAAE,CAAC;YACtD,CAAC,CAAC;YACF,MAAM,EAAE,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,mBAAmB,EAAE,KAAK,EAAE,MAAM,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE;gBAC3F,OAAO,EAAE,KAAK,EAAE,CAAC,EAAE,SAAS,EAAE,iBAAiB,EAAE,CAAC;YACtD,CAAC,CAAC;YACF,IAAI,EAAE,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,iBAAiB,EAAE,KAAK,EAAE,IAAI,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE;gBACrF,OAAO,EAAE,GAAG,EAAE,CAAC,EAAE,SAAS,EAAE,iBAAiB,EAAE,CAAC;YACpD,CAAC,CAAC;YACF,cAAc,EAAE,IAAI,CAAC,yBAAyB,CAAC,KAAK,EAAE,QAAQ,IAAI,EAAE,EAAE,SAAS,EAAE,YAAY,CAAC;YAC9F,KAAK,EACD,KAAK,YAAY,SAAS;gBACtB,CAAC,CAAC,IAAI,KAAK,CACL,IAAI,CAAC,gBAAgB,EACrB,KAAK,CAAC,OAAO,EACb,KAAK,CAAC,OAAO,EACb,QAAQ,CAAC,UAAU,EACnB,QAAQ,CAAC,SAAS,EAClB,SAAS,EACT,iBAAiB,CACpB;gBACH,CAAC,CAAC,IAAI;SACjB,CAAC;IACN,CAAC;IAED,sBAAsB,CAClB,KAAwB,EACxB,UAA6B,EAC7B,SAAiB,EACjB,iBAAyC,EACzC,YAAoB,EACpB,SAAiB,EACjB,IAAY;QAEZ,IAAI,IAAI,KAAK,qBAAqB,IAAI,IAAI,KAAK,YAAY,EAAE;YACzD,OAAO,IAAI,CAAC;SACf;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,IAAI,EAAE,SAAS,CAAC,CAAC;QACjE,IAAI,SAAS,EAAE;YACX,OAAO,SAAS,CAAC;SACpB;QAED,MAAM,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,KAAK,SAAS,CAAC,CAAC;QAClE,IAAI,KAAK,EAAE;YACP,OAAO,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,mBAAmB,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,iBAAiB,EAAE,CAAC,CAAC;SAChH;QAED,MAAM,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,KAAK,SAAS,CAAC,CAAC;QAClE,IAAI,KAAK,EAAE;YACP,OAAO,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,mBAAmB,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,iBAAiB,EAAE,CAAC,CAAC;SAChH;QAED,MAAM,GAAG,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,KAAK,SAAS,CAAC,CAAC;QAC9D,IAAI,GAAG,EAAE;YACL,OAAO,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,iBAAiB,EAAE,EAAE,GAAG,EAAE,SAAS,EAAE,iBAAiB,EAAE,CAAC,CAAC;SAC5G;QAED,MAAM,OAAO,GAAG,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,KAAK,SAAS,CAAC,CAAC;QACtE,IAAI,OAAO,EAAE;YACT,OAAO,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;gBACjF,OAAO,EAAE,OAAO;gBAChB,SAAS;gBACT,YAAY;aACf,CAAC,CAAC;SACN;QAED,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,yBAAyB,CAAC,QAAwB,EAAE,SAAiB,EAAE,YAAoB;QACvF,OAAO,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;YACpB,MAAM,IAAI,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;YAC5C,OAAO,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,IAAI,EAAE,EAAE,OAAO,EAAE,CAAC,EAAE,SAAS,EAAE,YAAY,EAAE,CAAC,CAAC;QAClG,CAAC,CAAC,CAAC;IACP,CAAC;IAED,qBAAqB,CAAC,UAA6B,EAAE,SAA4B,EAAE,IAAY,EAAE,SAAiB;QAC9G,MAAM,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,IAAI,EAAE,SAAS,CAAC,CAAC;QAC/D,IAAI,OAAO,EAAE;YACT,OAAO;SACV;QAED,IAAI,SAAS,CAAC,aAAa,KAAK,mBAAmB,EAAE;YACjD,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,SAA8C,CAAC,CAAC;SAC1E;aAAM,IAAI,SAAS,CAAC,aAAa,KAAK,mBAAmB,EAAE;YACxD,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,SAA8C,CAAC,CAAC;SAC1E;aAAM,IAAI,SAAS,CAAC,aAAa,KAAK,iBAAiB,EAAE;YACtD,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,SAA4C,CAAC,CAAC;SACtE;aAAM;YACH,UAAU,CAAC,cAAc,CAAC,IAAI,CAAC,SAA6C,CAAC,CAAC;SACjF;IACL,CAAC;IAED,0BAA0B,CAAC,UAA6B,EAAE,YAAoB,EAAE,gBAA+B;QAC3G,IAAI,YAAY,CAAC,QAAQ,CAAC,qBAAqB,CAAC,EAAE;YAC9C,OAAO,CACH,IAAI,CAAC,2BAA2B,CAAC,UAAU,CAAC,MAAM,EAAE,gBAAgB,CAAC;gBACrE,IAAI,CAAC,2BAA2B,CAAC,UAAU,CAAC,IAAI,EAAE,gBAAgB,CAAC;gBACnE,IAAI,CAAC,2BAA2B,CAAC,UAAU,CAAC,cAAc,EAAE,gBAAgB,CAAC,CAChF,CAAC;SACL;QAED,IAAI,YAAY,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE;YACrC,OAAO,IAAI,CAAC,2BAA2B,CAAC,UAAU,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;SAChF;QAED,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,aAAa,CAAC,UAA6B,EAAE,QAAuB;QAChE,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,WAAW,IAAI,QAAQ,CAAC,KAAK,IAAI,CAAC,CAAC,QAAQ,CAAC,WAAW,IAAI,QAAQ,CAAC,GAAG,CAAC,CAAC;QACjI,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,WAAW,IAAI,QAAQ,CAAC,KAAK,IAAI,CAAC,CAAC,QAAQ,CAAC,WAAW,IAAI,QAAQ,CAAC,GAAG,CAAC,CAAC;QACjI,MAAM,IAAI,GAAG,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,WAAW,IAAI,QAAQ,CAAC,KAAK,IAAI,CAAC,CAAC,QAAQ,CAAC,WAAW,IAAI,QAAQ,CAAC,GAAG,CAAC,CAAC;QAC7H,MAAM,MAAM,GAAG,UAAU,CAAC,cAAc,CAAC,MAAM,CAC3C,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,WAAW,IAAI,QAAQ,CAAC,KAAK,IAAI,CAAC,CAAC,QAAQ,CAAC,WAAW,IAAI,QAAQ,CAAC,GAAG,CAC1F,CAAC;QACF,OAAO,CAAC,GAAG,MAAM,EAAE,GAAG,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,WAAW,GAAG,CAAC,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;IACtH,CAAC;IAED,YAAY,CAAC,UAA6B,EAAE,IAAY,EAAE,SAAiB;QACvE,IAAI,IAAI,KAAK,qBAAqB,EAAE;YAChC,OAAO,CACH,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,MAAM,EAAE,SAAS,CAAC;gBAChD,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,IAAI,EAAE,SAAS,CAAC;gBAC9C,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,cAAc,EAAE,SAAS,CAAC,CAC3D,CAAC;SACL;QAED,OAAO,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IAC5D,CAAC;IAED,qBAAqB,CACjB,SAA2C,EAC3C,QAAuB,EACvB,YAAoB,EACpB,OAAgB,EAChB,IAAqB;QAErB,IAAI,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QACzB,IAAI,SAAS,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE;YACzC,MAAM;gBACF,SAAS,CAAC,QAAQ,YAAY,mBAAmB,CAAC,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC;SAChI;QAED,OAAO,IAAI,YAAY,CAAC;YACpB,KAAK,EAAE,SAAS,CAAC,QAAQ,CAAC,KAAK;YAC/B,MAAM;YACN,QAAQ,EAAE,CAAC;YACX,OAAO,EAAE,CAAC;YACV,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,MAAM,EAAE,SAAS,CAAC,QAAQ,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM;YAChD,OAAO,EAAE,CAAC;YACV,IAAI,EAAE,CAAC;YACP,WAAW,EAAE,QAAQ,CAAC,WAAW;YACjC,UAAU,EAAE,CAAC;YACb,KAAK,EAAE,QAAQ,CAAC,KAAK;YACrB,eAAe,EAAE,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,uBAAuB,CAAC,eAAe;YAC9F,aAAa,EAAE,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,uBAAuB,CAAC,aAAa;YACxF,UAAU,EAAE,QAAQ,CAAC,MAAM,CAAC,IAAI;YAChC,WAAW,EAAE,QAAQ,CAAC,MAAM,CAAC,KAAK;YAClC,YAAY,EAAE,QAAQ,CAAC,YAAY;YACnC,WAAW,EAAE,QAAQ,CAAC,WAAW;YACjC,WAAW,EAAE,KAAK;YAClB,WAAW,EAAE,KAAK;YAClB,YAAY;YACZ,KAAK,EAAE,SAAS,CAAC,QAAQ,YAAY,iBAAiB;YACtD,OAAO,EAAE,SAAS,CAAC,QAAQ,YAAY,mBAAmB;SAC7D,CAAC,CAAC;IACP,CAAC;IAED,iBAAiB,CAAC,IAAY;QAC1B,OAAO,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC,aAAa,CAAC;IAClE,CAAC;IAEO,2BAA2B,CAAC,UAA8C,EAAE,QAAuB;QACvG,OAAO,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,WAAW,IAAI,QAAQ,CAAC,KAAK,IAAI,CAAC,CAAC,QAAQ,CAAC,WAAW,IAAI,QAAQ,CAAC,GAAG,CAAC,CAAC;IACpH,CAAC;IAEO,aAAa,CAAI,UAA6B,EAAE,WAAmB;QACvE,OAAO,UAAU,CAAC,IAAI,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,WAAW,KAAK,WAAW,CAAC,CAAC;IAC/E,CAAC;+GApMQ,oBAAoB;mHAApB,oBAAoB;;4FAApB,oBAAoB;kBADhC,UAAU","sourcesContent":["import { ComponentRef, Injectable, Injector, Type } from '@angular/core';\n\nimport { BaseNoderComponent } from '../abstract/base.component';\nimport { ComponentService } from './component.service';\nimport { ContentsInterface } from '../../../content/contents.interface';\nimport { CUSTOM_ELEMENT_MARKER, TABLE_MARKER } from '../custom-content-markers.const';\nimport { DEFAULT_PARAGRAPH_STYLE } from '../../../content/constants/editor.const';\nimport { DisplayToken } from '../../../content/display-data/display-token.model';\nimport { DistanceModel } from '../../../execution/distance.model';\nimport { Document } from '../../../content/display-data/document';\nimport { DocxModel } from '../../../../models/generated/docx.model';\nimport { Edges } from '../../edges/edges';\nimport { ElementModel } from '../../../../models/generated/element.model';\nimport { EXTERNAL_ELEMENT_SERVICE } from '../../external-element/external-elements.const';\nimport { ExternalElementModel } from '../../external-element/models/external-element.model';\nimport { GeneralPropertiesModel } from '../../../content/display-data/general-properties.model';\nimport { ICustomComponents } from '../custom-components.interface';\nimport { IFontMetricSize } from '../../../gadgets/font-metrics/font-metric-size.interface';\nimport { LineInfoModel } from '../../../content/display-data/line-info.model';\nimport { NoderImageComponent } from '../../image/components/image.component';\nimport { NoderTabComponent } from '../../tab/tab.component';\nimport { NoderTableComponent } from '../../table/components/table.component';\n\n@Injectable()\nexport class CustomContentService {\n    elements: ExternalElementModel[];\n\n    constructor(public componentService: ComponentService, private injector: Injector) {\n        this.elements = this.injector.get(EXTERNAL_ELEMENT_SERVICE).elements;\n    }\n\n    generateComponents(\n        model: ContentsInterface,\n        sessionId: number,\n        generalProperties: GeneralPropertiesModel,\n        document: Document\n    ): ICustomComponents {\n        const contentWidth = document.pageWidth - (document.pageMargin.left + document.pageMargin.right);\n        return {\n            images: this.componentService.generateComponents(NoderImageComponent, model?.images || [], x => {\n                return { image: x, sessionId, generalProperties };\n            }),\n            tables: this.componentService.generateComponents(NoderTableComponent, model?.tables || [], x => {\n                return { table: x, sessionId, generalProperties };\n            }),\n            tabs: this.componentService.generateComponents(NoderTabComponent, model?.tabs || [], x => {\n                return { tab: x, sessionId, generalProperties };\n            }),\n            customElements: this.generateElementComponents(model?.elements || [], sessionId, contentWidth),\n            edges:\n                model instanceof DocxModel\n                    ? new Edges(\n                          this.componentService,\n                          model.headers,\n                          model.footers,\n                          document.pageMargin,\n                          document.pageWidth,\n                          sessionId,\n                          generalProperties\n                      )\n                    : null\n        };\n    }\n\n    getOrGenerateComponent(\n        model: ContentsInterface,\n        components: ICustomComponents,\n        sessionId: number,\n        generalProperties: GeneralPropertiesModel,\n        contentWidth: number,\n        charIndex: number,\n        char: string\n    ): ComponentRef<BaseNoderComponent> | null {\n        if (char !== CUSTOM_ELEMENT_MARKER && char !== TABLE_MARKER) {\n            return null;\n        }\n\n        const component = this.getComponent(components, char, charIndex);\n        if (component) {\n            return component;\n        }\n\n        const image = model.images.find(x => x.insertIndex === charIndex);\n        if (image) {\n            return this.componentService.generateComponent(NoderImageComponent, { image, sessionId, generalProperties });\n        }\n\n        const table = model.tables.find(x => x.insertIndex === charIndex);\n        if (table) {\n            return this.componentService.generateComponent(NoderTableComponent, { table, sessionId, generalProperties });\n        }\n\n        const tab = model.tabs.find(x => x.insertIndex === charIndex);\n        if (tab) {\n            return this.componentService.generateComponent(NoderTabComponent, { tab, sessionId, generalProperties });\n        }\n\n        const element = model.elements.find(x => x.insertIndex === charIndex);\n        if (element) {\n            return this.componentService.generateComponent(this.findComponentType(element.type), {\n                content: element,\n                sessionId,\n                contentWidth\n            });\n        }\n\n        return null;\n    }\n\n    generateElementComponents(elements: ElementModel[], sessionId: number, contentWidth: number): ComponentRef<BaseNoderComponent>[] {\n        return elements.map(x => {\n            const type = this.findComponentType(x.type);\n            return this.componentService.generateComponent(type, { content: x, sessionId, contentWidth });\n        });\n    }\n\n    addToCustomComponents(components: ICustomComponents, component: ComponentRef<any>, char: string, charIndex: number): void {\n        const existed = this.getComponent(components, char, charIndex);\n        if (existed) {\n            return;\n        }\n\n        if (component.componentType === NoderImageComponent) {\n            components.images.push(component as ComponentRef<NoderImageComponent>);\n        } else if (component.componentType === NoderTableComponent) {\n            components.tables.push(component as ComponentRef<NoderTableComponent>);\n        } else if (component.componentType === NoderTabComponent) {\n            components.tabs.push(component as ComponentRef<NoderTabComponent>);\n        } else {\n            components.customElements.push(component as ComponentRef<BaseNoderComponent>);\n        }\n    }\n\n    isFragmentContainComponent(components: ICustomComponents, textFragment: string, fragmentDistance: DistanceModel): boolean {\n        if (textFragment.includes(CUSTOM_ELEMENT_MARKER)) {\n            return (\n                this.isFragmentContainComponents(components.images, fragmentDistance) ||\n                this.isFragmentContainComponents(components.tabs, fragmentDistance) ||\n                this.isFragmentContainComponents(components.customElements, fragmentDistance)\n            );\n        }\n\n        if (textFragment.includes(TABLE_MARKER)) {\n            return this.isFragmentContainComponents(components.tables, fragmentDistance);\n        }\n\n        return false;\n    }\n\n    getComponents(components: ICustomComponents, distance: DistanceModel): ComponentRef<BaseNoderComponent>[] {\n        const images = components.images.filter(x => x.instance.insertIndex >= distance.start && x.instance.insertIndex <= distance.end);\n        const tables = components.tables.filter(x => x.instance.insertIndex >= distance.start && x.instance.insertIndex <= distance.end);\n        const tabs = components.tabs.filter(x => x.instance.insertIndex >= distance.start && x.instance.insertIndex <= distance.end);\n        const custom = components.customElements.filter(\n            x => x.instance.insertIndex >= distance.start && x.instance.insertIndex <= distance.end\n        );\n        return [...images, ...tables, ...tabs, ...custom].sort((a, b) => a.instance.insertIndex - b.instance.insertIndex);\n    }\n\n    getComponent(components: ICustomComponents, char: string, charIndex: number): ComponentRef<BaseNoderComponent> {\n        if (char === CUSTOM_ELEMENT_MARKER) {\n            return (\n                this.findComponent(components.images, charIndex) ??\n                this.findComponent(components.tabs, charIndex) ??\n                this.findComponent(components.customElements, charIndex)\n            );\n        }\n\n        return this.findComponent(components.tables, charIndex);\n    }\n\n    getTokenFromComponent(\n        component: ComponentRef<BaseNoderComponent>,\n        lineInfo: LineInfoModel,\n        displayValue: number,\n        isFirst: boolean,\n        size: IFontMetricSize\n    ): DisplayToken {\n        let height = size.height;\n        if (component.instance.height > size.height) {\n            height =\n                component.instance instanceof NoderImageComponent ? component.instance.height + size.descent : component.instance.height;\n        }\n\n        return new DisplayToken({\n            width: component.instance.width,\n            height,\n            baseline: 0,\n            content: 0,\n            font: size.font,\n            ascent: component.instance.height ?? size.height,\n            descent: 0,\n            line: 0,\n            lineSpacing: lineInfo.lineSpacing,\n            multiplier: 0,\n            align: lineInfo.align,\n            indentFirstLine: isFirst ? lineInfo.indent.firstLine : DEFAULT_PARAGRAPH_STYLE.indentFirstLine,\n            indentHanging: isFirst ? lineInfo.indent.hanging : DEFAULT_PARAGRAPH_STYLE.indentHanging,\n            indentLeft: lineInfo.indent.left,\n            indentRight: lineInfo.indent.right,\n            indentBefore: lineInfo.offsetBefore,\n            indentAfter: lineInfo.offsetAfter,\n            isPageBreak: false,\n            isLineBreak: false,\n            displayValue,\n            isTab: component.instance instanceof NoderTabComponent,\n            isTable: component.instance instanceof NoderTableComponent\n        });\n    }\n\n    findComponentType(type: number): Type<BaseNoderComponent> {\n        return this.elements.find(x => x.type === type).componentType;\n    }\n\n    private isFragmentContainComponents(components: ComponentRef<BaseNoderComponent>[], distance: DistanceModel): boolean {\n        return components.some(x => x.instance.insertIndex >= distance.start && x.instance.insertIndex <= distance.end);\n    }\n\n    private findComponent<T>(components: ComponentRef<T>[], insertIndex: number): ComponentRef<T> {\n        return components.find((x: any) => x.instance.insertIndex === insertIndex);\n    }\n}\n"]}
|
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-content.service.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-noder/src/lib/editor/components/shared/services/custom-content.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentRef, Injectable, Injector, Type } from '@angular/core';\n\nimport { BaseNoderComponent } from '../abstract/base.component';\nimport { ComponentService } from './component.service';\nimport { ContentsInterface } from '../../../content/contents.interface';\nimport { CUSTOM_ELEMENT_MARKER, TABLE_MARKER } from '../custom-content-markers.const';\nimport { DEFAULT_PARAGRAPH_STYLE } from '../../../content/constants/editor.const';\nimport { DisplayToken } from '../../../content/display-data/display-token.model';\nimport { DistanceModel } from '../../../execution/distance.model';\nimport { ElementModel } from '../../../../models/generated/element.model';\nimport { EXTERNAL_ELEMENT_SERVICE } from '../../external-element/external-elements.const';\nimport { ExternalElementModel } from '../../external-element/models/external-element.model';\nimport { GeneralPropertiesModel } from '../../../content/display-data/general-properties.model';\nimport { ICustomComponents } from '../custom-components.interface';\nimport { IFontMetricSize } from '../../../gadgets/font-metrics/font-metric-size.interface';\nimport { LineInfoModel } from '../../../content/display-data/line-info.model';\nimport { NoderImageComponent } from '../../image/components/image.component';\nimport { NoderTabComponent } from '../../tab/tab.component';\nimport { NoderTableComponent } from '../../table/components/table.component';\n\n@Injectable()\nexport class CustomContentService {\n    elements: ExternalElementModel[];\n\n    constructor(public componentService: ComponentService, private injector: Injector) {\n        this.elements = this.injector.get(EXTERNAL_ELEMENT_SERVICE).elements;\n    }\n\n    generateComponent(\n        model: ContentsInterface,\n        components: ICustomComponents,\n        sessionId: number,\n        generalProperties: GeneralPropertiesModel,\n        contentWidth: number,\n        charIndex: number\n    ): ComponentRef<BaseNoderComponent> | null {\n        const image = model.images.find(x => x.insertIndex === charIndex);\n        if (image) {\n            const component = this.componentService.generateComponent(NoderImageComponent, { image, sessionId, generalProperties });\n            components.images.push(component);\n            return component;\n        }\n\n        const table = model.tables.find(x => x.insertIndex === charIndex);\n        if (table) {\n            const component = this.componentService.generateComponent(NoderTableComponent, { table, sessionId, generalProperties });\n            components.tables.push(component);\n            return component;\n        }\n\n        const tab = model.tabs.find(x => x.insertIndex === charIndex);\n        if (tab) {\n            const component = this.componentService.generateComponent(NoderTabComponent, { tab, sessionId, generalProperties });\n            components.tabs.push(component);\n            return component;\n        }\n\n        const content = model.elements.find(x => x.insertIndex === charIndex);\n        if (content) {\n            const component = this.componentService.generateComponent(this.findComponentType(content.type), {\n                content,\n                sessionId,\n                contentWidth\n            });\n            components.customElements.push(component);\n            return component;\n        }\n\n        return null;\n    }\n\n    generateElementComponents(elements: ElementModel[], sessionId: number, contentWidth: number): ComponentRef<BaseNoderComponent>[] {\n        return elements.map(x => {\n            const type = this.findComponentType(x.type);\n            return this.componentService.generateComponent(type, { content: x, sessionId, contentWidth });\n        });\n    }\n\n    isFragmentContainComponent(components: ICustomComponents, textFragment: string, fragmentDistance: DistanceModel): boolean {\n        if (textFragment.includes(CUSTOM_ELEMENT_MARKER)) {\n            return (\n                this.isFragmentContainComponents(components.images, fragmentDistance) ||\n                this.isFragmentContainComponents(components.tabs, fragmentDistance) ||\n                this.isFragmentContainComponents(components.customElements, fragmentDistance)\n            );\n        }\n\n        if (textFragment.includes(TABLE_MARKER)) {\n            return this.isFragmentContainComponents(components.tables, fragmentDistance);\n        }\n\n        return false;\n    }\n\n    getComponents(components: ICustomComponents, distance: DistanceModel): ComponentRef<BaseNoderComponent>[] {\n        const images = components.images.filter(x => x.instance.insertIndex >= distance.start && x.instance.insertIndex <= distance.end);\n        const tables = components.tables.filter(x => x.instance.insertIndex >= distance.start && x.instance.insertIndex <= distance.end);\n        const tabs = components.tabs.filter(x => x.instance.insertIndex >= distance.start && x.instance.insertIndex <= distance.end);\n        const custom = components.customElements.filter(\n            x => x.instance.insertIndex >= distance.start && x.instance.insertIndex <= distance.end\n        );\n        return [...images, ...tables, ...tabs, ...custom].sort((a, b) => a.instance.insertIndex - b.instance.insertIndex);\n    }\n\n    getComponent(components: ICustomComponents, char: string, charIndex: number): ComponentRef<BaseNoderComponent> {\n        if (char === CUSTOM_ELEMENT_MARKER) {\n            return (\n                this.findComponent(components.images, charIndex) ??\n                this.findComponent(components.tabs, charIndex) ??\n                this.findComponent(components.customElements, charIndex)\n            );\n        }\n\n        return this.findComponent(components.tables, charIndex);\n    }\n\n    getTokenFromComponent(\n        component: ComponentRef<BaseNoderComponent>,\n        lineInfo: LineInfoModel,\n        displayValue: number,\n        isFirst: boolean,\n        size: IFontMetricSize\n    ): DisplayToken {\n        let height = size.height;\n        if (component.instance.height > size.height) {\n            height =\n                component.instance instanceof NoderImageComponent ? component.instance.height + size.descent : component.instance.height;\n        }\n\n        return new DisplayToken({\n            width: component.instance.width,\n            height,\n            baseline: 0,\n            content: 0,\n            font: size.font,\n            ascent: component.instance.height ?? size.height,\n            descent: 0,\n            line: 0,\n            lineSpacing: lineInfo.lineSpacing,\n            multiplier: 0,\n            align: lineInfo.align,\n            indentFirstLine: isFirst ? lineInfo.indent.firstLine : DEFAULT_PARAGRAPH_STYLE.indentFirstLine,\n            indentHanging: isFirst ? lineInfo.indent.hanging : DEFAULT_PARAGRAPH_STYLE.indentHanging,\n            indentLeft: lineInfo.indent.left,\n            indentRight: lineInfo.indent.right,\n            indentBefore: lineInfo.offsetBefore,\n            indentAfter: lineInfo.offsetAfter,\n            isPageBreak: false,\n            isLineBreak: false,\n            displayValue,\n            isTab: component.instance instanceof NoderTabComponent,\n            isTable: component.instance instanceof NoderTableComponent\n        });\n    }\n\n    findComponentType(type: number): Type<BaseNoderComponent> {\n        return this.elements.find(x => x.type === type).componentType;\n    }\n\n    findComponent<T>(components: ComponentRef<T>[], insertIndex: number): ComponentRef<T> {\n        return components.find((x: any) => x.instance.insertIndex === insertIndex);\n    }\n\n    private isFragmentContainComponents(components: ComponentRef<BaseNoderComponent>[], distance: DistanceModel): boolean {\n        return components.some(x => x.instance.insertIndex >= distance.start && x.instance.insertIndex <= distance.end);\n    }\n\n    isSpecialMarker(char: string): boolean {\n        return char === CUSTOM_ELEMENT_MARKER || char === TABLE_MARKER;\n    }\n}\n"]}
|
|
@@ -28,7 +28,7 @@ export class NoderTableCellComponent {
|
|
|
28
28
|
};
|
|
29
29
|
}
|
|
30
30
|
ngOnDestroy() {
|
|
31
|
-
this.session?.
|
|
31
|
+
this.session?.displayData.removeEventListener('pagesCountChanged', this.pagesCountChangedHandler);
|
|
32
32
|
this.regulatorService.removeSession(this.sessionId);
|
|
33
33
|
}
|
|
34
34
|
initialize() {
|
|
@@ -45,18 +45,18 @@ export class NoderTableCellComponent {
|
|
|
45
45
|
this.addEventListeners();
|
|
46
46
|
}
|
|
47
47
|
getCellContentHeight() {
|
|
48
|
-
this._allParagraphsHeight = this.session.
|
|
48
|
+
this._allParagraphsHeight = this.session.displayData.getAllParagraphsHeight();
|
|
49
49
|
return this._allParagraphsHeight;
|
|
50
50
|
}
|
|
51
|
-
|
|
52
|
-
this.editorService.
|
|
51
|
+
disableEditorSelection() {
|
|
52
|
+
this.editorService.disableSelection();
|
|
53
53
|
}
|
|
54
54
|
onStartResizing(event, border) {
|
|
55
55
|
event.stopPropagation();
|
|
56
56
|
this.startResizing(new CellResizerParametersModel(this.columnIndex, this.rowIndex, this.cellIndex, border));
|
|
57
57
|
}
|
|
58
58
|
addEventListeners() {
|
|
59
|
-
this.session.
|
|
59
|
+
this.session.displayData.addEventListener('pagesCountChanged', this.pagesCountChangedHandler);
|
|
60
60
|
}
|
|
61
61
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NoderTableCellComponent, deps: [{ token: i1.EditorService }, { token: i2.RegulatorService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
62
62
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: NoderTableCellComponent, selector: "app-nod-table-cell", inputs: { table: "table", cell: "cell", rowIndex: "rowIndex", cellIndex: "cellIndex", columnIndex: "columnIndex", width: "width", parentSessionId: "parentSessionId", generalProperties: "generalProperties", heightChanged: "heightChanged", startResizing: "startResizing" }, host: { properties: { "class.highlighted": "this.isHighlighted", "attr.data-session-id": "this.sessionId" } }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true, static: true }], ngImport: i0, template: "<div\n *ngIf=\"cellIndex === 0\"\n class=\"resizer left-border\"\n (mousedown)=\"onStartResizing($event, resizerBorder.Left)\"></div>\n<div\n #container\n class=\"edit-container\"></div>\n<div class=\"highlight-container\"></div>\n<div\n class=\"resizer right-border\"\n (mousedown)=\"onStartResizing($event, resizerBorder.Right)\"></div>\n", styles: [".highlight-container{visibility:hidden;position:absolute;width:100%;height:100%;background-color:#5ea8f766;pointer-events:none;overflow:hidden}:host{display:flex;position:relative;min-height:19px;height:100%;background:transparent}:host.highlighted .highlight-container{visibility:visible}.edit-container{min-height:1px;overflow:hidden}.left-border{left:-6px}.resizer{cursor:col-resize;width:11px;height:100%;position:absolute;z-index:1}.right-border{right:-6px}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
@@ -94,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
94
94
|
type: ViewChild,
|
|
95
95
|
args: ['container', { static: true }]
|
|
96
96
|
}] } });
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-cell.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-noder/src/lib/editor/components/table/components/table-cell.component.ts","../../../../../../../../projects/ngx-noder/src/lib/editor/components/table/components/table-cell.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, HostBinding, Input, ViewChild } from '@angular/core';\n\nimport { CellModel } from '../../../../models/generated/cell.model';\nimport { CellResizerParametersModel } from '../../../components/table/models/cell-resizer-parameters.model';\nimport { EditSession } from '../../../execution/edit.session';\nimport { EditorService } from '../../../interaction/editor.service';\nimport { GeneralPropertiesModel } from '../../../content/display-data/general-properties.model';\nimport { MarginModel } from '../../../content/margin.model';\nimport { RegulatorService } from '../../../execution/regulator.service';\nimport { Renderer } from '../../../display/renderer';\nimport { ResizerSide } from '../../../components/table/enums/reisizer-side.enum';\nimport { SessionModel } from '../../../execution/targeting/session.model';\nimport { TableModel } from '../../../../models/generated/table.model';\nimport { VirtualRenderer } from '../../../display/virtual.renderer';\n\n@Component({\n    selector: 'app-nod-table-cell',\n    templateUrl: './table-cell.component.html',\n    styleUrls: ['./table-cell.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class NoderTableCellComponent {\n    @Input() table: TableModel;\n\n    @Input() cell: CellModel;\n\n    @Input() rowIndex: number;\n\n    @Input() cellIndex: number;\n\n    @Input() columnIndex: number;\n\n    @Input() width: number;\n\n    @Input() parentSessionId: number;\n\n    @Input() generalProperties: GeneralPropertiesModel;\n\n    @Input() heightChanged: (rowIndex: number, cellIndex: number, height: number) => void;\n\n    @Input() startResizing: (cellResizerParameters: CellResizerParametersModel) => void;\n\n    @HostBinding('class.highlighted')\n    isHighlighted = false;\n\n    @HostBinding('attr.data-session-id')\n    sessionId: number;\n\n    cellSession: SessionModel;\n\n    get session(): EditSession {\n        return this.cellSession.session;\n    }\n\n    get renderer(): Renderer | VirtualRenderer {\n        return this.cellSession.renderer;\n    }\n\n    @ViewChild('container', { static: true }) container: ElementRef<HTMLElement>;\n\n    readonly resizerBorder = ResizerSide;\n\n    private _allParagraphsHeight: number;\n\n    constructor(private editorService: EditorService, private regulatorService: RegulatorService) {}\n\n    ngOnDestroy(): void {\n        this.session?.displayData.removeEventListener('pagesCountChanged', this.pagesCountChangedHandler);\n        this.regulatorService.removeSession(this.sessionId);\n    }\n\n    initialize(): void {\n        const marginModel = new MarginModel({\n            left: 7,\n            right: 7,\n            top: 0,\n            bottom: 0,\n            header: 0,\n            footer: 0\n        });\n        this.cellSession = this.regulatorService.addCellSession(this.table, marginModel, this, this.generalProperties);\n        this.sessionId = this.cellSession.sessionId;\n        this.addEventListeners();\n    }\n\n    getCellContentHeight(): number {\n        this._allParagraphsHeight = this.session.displayData.getAllParagraphsHeight();\n        return this._allParagraphsHeight;\n    }\n\n    disableEditorSelection(): void {\n        this.editorService.disableSelection();\n    }\n\n    onStartResizing(event: MouseEvent, border: ResizerSide): void {\n        event.stopPropagation();\n\n        this.startResizing(new CellResizerParametersModel(this.columnIndex, this.rowIndex, this.cellIndex, border));\n    }\n\n    private addEventListeners(): void {\n        this.session.displayData.addEventListener('pagesCountChanged', this.pagesCountChangedHandler);\n    }\n\n    private pagesCountChangedHandler = (event: { pageHeight: number }): void => {\n        if (this._allParagraphsHeight === event.pageHeight) {\n            return;\n        }\n\n        this._allParagraphsHeight = event.pageHeight;\n        const cellContentHeight = this._allParagraphsHeight;\n        this.heightChanged(this.rowIndex, this.cellIndex, cellContentHeight);\n    };\n}\n","<div\n    *ngIf=\"cellIndex === 0\"\n    class=\"resizer left-border\"\n    (mousedown)=\"onStartResizing($event, resizerBorder.Left)\"></div>\n<div\n    #container\n    class=\"edit-container\"></div>\n<div class=\"highlight-container\"></div>\n<div\n    class=\"resizer right-border\"\n    (mousedown)=\"onStartResizing($event, resizerBorder.Right)\"></div>\n"]}
|