@talrace/ngx-noder 0.0.11 → 0.0.13

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.
Files changed (80) hide show
  1. package/README.md +374 -71
  2. package/esm2022/lib/apart-components/editor-title/editor-title.component.mjs +1 -1
  3. package/esm2022/lib/apart-components/editor-toolbar/components/buttons/font/font.component.mjs +2 -2
  4. package/esm2022/lib/apart-components/editor-toolbar/components/menu-dropdowns/menu-dropdowns.component.mjs +2 -5
  5. package/esm2022/lib/apart-components/editor-toolbar/editor-toolbar/editor-toolbar.component.mjs +3 -3
  6. package/esm2022/lib/editor/components/edges/edge-element.model.mjs +30 -1
  7. package/esm2022/lib/editor/components/edges/edge.component.mjs +23 -23
  8. package/esm2022/lib/editor/components/edges/edges.mjs +30 -15
  9. package/esm2022/lib/editor/components/image/components/image.component.mjs +2 -2
  10. package/esm2022/lib/editor/components/image/input-handler/image-input.handler.mjs +2 -2
  11. package/esm2022/lib/editor/components/table/components/table-cell.component.mjs +5 -3
  12. package/esm2022/lib/editor/components/table/components/table.component.mjs +7 -5
  13. package/esm2022/lib/editor/components/table/selection/table-selection.mjs +12 -5
  14. package/esm2022/lib/editor/content/display-data/display-data.mjs +4 -4
  15. package/esm2022/lib/editor/content/helpers/content-style.helper.mjs +1 -1
  16. package/esm2022/lib/editor/content/helpers/link.helper.mjs +39 -3
  17. package/esm2022/lib/editor/display/layers/text.layer.mjs +100 -75
  18. package/esm2022/lib/editor/display/print/print.helper.mjs +3 -3
  19. package/esm2022/lib/editor/display/print/print.renderer.mjs +5 -5
  20. package/esm2022/lib/editor/display/renderer.mjs +23 -25
  21. package/esm2022/lib/editor/display/virtual.renderer.mjs +10 -43
  22. package/esm2022/lib/editor/execution/edit.session.mjs +26 -16
  23. package/esm2022/lib/editor/execution/editor.mjs +88 -127
  24. package/esm2022/lib/editor/execution/regulator.service.mjs +44 -39
  25. package/esm2022/lib/editor/execution/targeting/cell-session-source.model.mjs +2 -3
  26. package/esm2022/lib/editor/execution/targeting/edge-session-source.model.mjs +2 -3
  27. package/esm2022/lib/editor/execution/targeting/main-session-source.model.mjs +2 -2
  28. package/esm2022/lib/editor/execution/targeting/session-source.model.mjs +1 -1
  29. package/esm2022/lib/editor/gadgets/history/operation-history.mjs +39 -37
  30. package/esm2022/lib/editor/interaction/editor.service.mjs +22 -22
  31. package/esm2022/lib/editor/interaction/mouse.handler.mjs +2 -2
  32. package/esm2022/lib/editor/operations/helpers/content-operations.helper.mjs +4 -4
  33. package/esm2022/lib/editor/operations/helpers/format-operations.helper.mjs +2 -2
  34. package/esm2022/lib/editor/operations/helpers/link-operations.helper.mjs +59 -7
  35. package/esm2022/lib/editor/operations/operations-helper.helper.mjs +24 -25
  36. package/esm2022/lib/editor/operations/save-commands.helper.mjs +6 -5
  37. package/esm2022/lib/editor/positioning/content.helper.mjs +10 -1
  38. package/esm2022/lib/editor/positioning/position.helper.mjs +49 -35
  39. package/esm2022/lib/editor/revision.helper.mjs +3 -1
  40. package/esm2022/lib/models/generated/delete.model.mjs +1 -1
  41. package/esm2022/lib/models/generated/link-data.model.mjs +1 -1
  42. package/esm2022/lib/models/generated/link.model.mjs +1 -1
  43. package/esm2022/lib/models/generated/restore-text-styles.model.mjs +1 -1
  44. package/esm2022/lib/models/generated/target.model.mjs +1 -1
  45. package/fesm2022/talrace-ngx-noder.mjs +672 -545
  46. package/fesm2022/talrace-ngx-noder.mjs.map +1 -1
  47. package/lib/apart-components/editor-toolbar/components/menu-dropdowns/menu-dropdowns.component.d.ts +1 -3
  48. package/lib/apart-components/editor-toolbar/editor-toolbar/editor-toolbar.component.d.ts +1 -1
  49. package/lib/editor/components/edges/edge-element.model.d.ts +9 -1
  50. package/lib/editor/components/edges/edge.component.d.ts +4 -4
  51. package/lib/editor/components/edges/edges.d.ts +8 -2
  52. package/lib/editor/components/table/components/table.component.d.ts +4 -2
  53. package/lib/editor/components/table/selection/table-selection.d.ts +5 -2
  54. package/lib/editor/content/display-data/display-data.d.ts +2 -1
  55. package/lib/editor/content/helpers/content-style.helper.d.ts +1 -1
  56. package/lib/editor/content/helpers/link.helper.d.ts +4 -1
  57. package/lib/editor/display/layers/text.layer.d.ts +8 -10
  58. package/lib/editor/display/print/print.helper.d.ts +1 -2
  59. package/lib/editor/display/print/print.renderer.d.ts +1 -2
  60. package/lib/editor/display/renderer.d.ts +9 -9
  61. package/lib/editor/display/virtual.renderer.d.ts +3 -10
  62. package/lib/editor/execution/edit.session.d.ts +7 -2
  63. package/lib/editor/execution/editor.d.ts +10 -9
  64. package/lib/editor/execution/regulator.service.d.ts +6 -4
  65. package/lib/editor/execution/targeting/cell-session-source.model.d.ts +0 -1
  66. package/lib/editor/execution/targeting/edge-session-source.model.d.ts +0 -1
  67. package/lib/editor/execution/targeting/session-source.model.d.ts +0 -1
  68. package/lib/editor/gadgets/history/operation-history.d.ts +7 -3
  69. package/lib/editor/interaction/editor.service.d.ts +13 -12
  70. package/lib/editor/operations/helpers/content-operations.helper.d.ts +1 -1
  71. package/lib/editor/operations/helpers/link-operations.helper.d.ts +7 -2
  72. package/lib/editor/operations/operations-helper.helper.d.ts +3 -3
  73. package/lib/editor/operations/save-commands.helper.d.ts +1 -1
  74. package/lib/editor/positioning/content.helper.d.ts +2 -0
  75. package/lib/editor/positioning/position.helper.d.ts +21 -6
  76. package/lib/models/generated/delete.model.d.ts +1 -1
  77. package/lib/models/generated/restore-text-styles.model.d.ts +1 -0
  78. package/lib/models/generated/target.model.d.ts +0 -1
  79. package/package.json +1 -1
  80. package/src/scss/base-editor.scss +4 -0
@@ -1,5 +1,4 @@
1
- import { ChangeDetectionStrategy, Component, HostBinding, Input, ViewChild } from '@angular/core';
2
- import { takeUntil } from 'rxjs';
1
+ import { ChangeDetectionStrategy, Component, Input, ViewChild } from '@angular/core';
3
2
  import { DestroyComponent } from '../shared/abstract/destroy.component';
4
3
  import { DomHelper } from '../../execution/helpers/dom.helper';
5
4
  import { EdgeType } from './edge-type.enum';
@@ -27,53 +26,57 @@ export class NoderEdgeComponent extends DestroyComponent {
27
26
  get renderer() {
28
27
  return this.edgeSession.renderer;
29
28
  }
30
- get height() {
29
+ get contentHeight() {
31
30
  return this.session.displayData.defaultVerticalData.contentHeight;
32
31
  }
33
32
  constructor(regulatorService, editorService) {
34
33
  super();
35
34
  this.regulatorService = regulatorService;
36
35
  this.editorService = editorService;
36
+ this.pagesCountChangedHandler = (event) => {
37
+ if (this._height === event.pageHeight) {
38
+ return;
39
+ }
40
+ this._height = event.pageHeight;
41
+ this.applyHeight();
42
+ this.editorService.changedEdgeSize(this.type, this.model.pageType);
43
+ };
37
44
  }
38
45
  ngOnDestroy() {
46
+ this.session?.displayData.removeEventListener('pagesCountChanged', this.pagesCountChangedHandler);
39
47
  this.regulatorService.removeSession(this.sessionId);
40
48
  super.ngOnDestroy();
41
49
  }
42
50
  initialize() {
43
51
  this.edgeSession = this.regulatorService.addEdgeSession(this);
44
52
  this.sessionId = this.edgeSession.sessionId;
45
- this._previousHeight = this.height;
53
+ this.container.nativeElement.parentElement.setAttribute('data-session-id', `${this.sessionId}`);
46
54
  DomHelper.setStyle(this.container.nativeElement.style, 'overflow', 'hidden');
47
55
  DomHelper.setStyle(this.typeContainer.nativeElement.style, 'visibility', 'hidden');
48
- this.setTypeContainerPosition();
49
- this.editorService.rendererUpdated$.pipe(takeUntil(this.destroy$)).subscribe(x => this.rendererUpdated(x));
56
+ this.applyHeight();
57
+ this.session.displayData.addEventListener('pagesCountChanged', this.pagesCountChangedHandler);
50
58
  }
51
59
  enterEditMode() {
52
60
  DomHelper.addCssClass(this.container.nativeElement, this.editModeClass);
53
61
  DomHelper.setStyle(this.typeContainer.nativeElement.style, 'visibility', 'visible');
62
+ this.editorService.changedEdge(this.sessionId);
54
63
  }
55
64
  leaveEditMode() {
56
65
  DomHelper.removeCssClass(this.container.nativeElement, this.editModeClass);
57
66
  DomHelper.setStyle(this.typeContainer.nativeElement.style, 'visibility', 'hidden');
67
+ this.editorService.changedEdge(this.sessionId);
58
68
  }
59
- rendererUpdated(sessionId) {
60
- if (sessionId !== this.sessionId || this.height === this._previousHeight) {
61
- return;
62
- }
63
- this.editorService.changedEdgeHeight(this.type);
64
- this._previousHeight = this.height;
65
- this.setTypeContainerPosition();
66
- }
67
- setTypeContainerPosition() {
68
- const renderedEdgeHeight = this.height > this.generalProperties.maxEdgeHeight ? this.generalProperties.maxEdgeHeight : this.height;
69
- DomHelper.setStyle(this.typeContainer.nativeElement.style, this.typeContainerPosition, `${renderedEdgeHeight}px`);
69
+ applyHeight() {
70
+ const maxHeight = this.generalProperties.maxEdgeHeight;
71
+ const height = this.contentHeight > maxHeight ? maxHeight : this.contentHeight;
72
+ DomHelper.setStyle(this.typeContainer.nativeElement.style, this.typeContainerPosition, `${height}px`);
70
73
  }
71
74
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NoderEdgeComponent, deps: [{ token: i1.RegulatorService }, { token: i2.EditorService }], target: i0.ɵɵFactoryTarget.Component }); }
72
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: NoderEdgeComponent, selector: "app-nod-edge", inputs: { model: "model", generalProperties: "generalProperties", margins: "margins", width: "width", parentSessionId: "parentSessionId", type: "type" }, host: { properties: { "attr.data-session-id": "this.sessionId" } }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true, static: true }, { propertyName: "typeContainer", first: true, predicate: ["locationType"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div\n #container\n class=\"edit-container\"></div>\n<div\n #locationType\n class=\"location-type\"></div>\n", styles: [":host{height:100%;width:100%;background:transparent;display:block}.location-type{position:absolute;height:auto;width:auto;font-size:9pt;background-color:#f2f2f2;border:1px solid #838282;border-radius:2px;padding:4px;margin-left:5px;z-index:2}.header-edit-mode{border-bottom:1px dashed #838282}.footer-edit-mode{border-top:1px dashed #838282}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
75
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: NoderEdgeComponent, selector: "app-nod-edge", inputs: { model: "model", generalProperties: "generalProperties", margins: "margins", width: "width", parentSessionId: "parentSessionId", type: "type" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true, static: true }, { propertyName: "typeContainer", first: true, predicate: ["locationType"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div\n #container\n class=\"edit-container\"></div>\n<div\n #locationType\n class=\"location-type\"></div>\n", styles: [":host{height:100%;width:100%;background:transparent;display:block}.location-type{position:absolute;height:auto;width:auto;font-size:9pt;color:#333;background-color:#f2f2f2;border:1px solid #838282;border-radius:2px;padding:4px;margin-left:5px;z-index:2}.header-edit-mode{border-bottom:1px dashed #838282}.footer-edit-mode{border-top:1px dashed #838282}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
73
76
  }
74
77
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NoderEdgeComponent, decorators: [{
75
78
  type: Component,
76
- args: [{ selector: 'app-nod-edge', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n #container\n class=\"edit-container\"></div>\n<div\n #locationType\n class=\"location-type\"></div>\n", styles: [":host{height:100%;width:100%;background:transparent;display:block}.location-type{position:absolute;height:auto;width:auto;font-size:9pt;background-color:#f2f2f2;border:1px solid #838282;border-radius:2px;padding:4px;margin-left:5px;z-index:2}.header-edit-mode{border-bottom:1px dashed #838282}.footer-edit-mode{border-top:1px dashed #838282}\n"] }]
79
+ args: [{ selector: 'app-nod-edge', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n #container\n class=\"edit-container\"></div>\n<div\n #locationType\n class=\"location-type\"></div>\n", styles: [":host{height:100%;width:100%;background:transparent;display:block}.location-type{position:absolute;height:auto;width:auto;font-size:9pt;color:#333;background-color:#f2f2f2;border:1px solid #838282;border-radius:2px;padding:4px;margin-left:5px;z-index:2}.header-edit-mode{border-bottom:1px dashed #838282}.footer-edit-mode{border-top:1px dashed #838282}\n"] }]
77
80
  }], ctorParameters: () => [{ type: i1.RegulatorService }, { type: i2.EditorService }], propDecorators: { model: [{
78
81
  type: Input
79
82
  }], generalProperties: [{
@@ -86,9 +89,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
86
89
  type: Input
87
90
  }], type: [{
88
91
  type: Input
89
- }], sessionId: [{
90
- type: HostBinding,
91
- args: ['attr.data-session-id']
92
92
  }], container: [{
93
93
  type: ViewChild,
94
94
  args: ['container', { static: true }]
@@ -96,4 +96,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
96
96
  type: ViewChild,
97
97
  args: ['locationType', { static: true }]
98
98
  }] } });
99
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edge.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-noder/src/lib/editor/components/edges/edge.component.ts","../../../../../../../projects/ngx-noder/src/lib/editor/components/edges/edge.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, HostBinding, Input, ViewChild } from '@angular/core';\nimport { takeUntil } from 'rxjs';\n\nimport { DestroyComponent } from '../shared/abstract/destroy.component';\nimport { DomHelper } from '../../execution/helpers/dom.helper';\nimport { EdgeModel } from '../../../models/generated/edge.model';\nimport { EdgeType } from './edge-type.enum';\nimport { EditorService } from '../../interaction/editor.service';\nimport { EditSession } from '../../execution/edit.session';\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 { SessionModel } from '../../execution/targeting/session.model';\nimport { VirtualRenderer } from '../../display/virtual.renderer';\n\n@Component({\n    selector: 'app-nod-edge',\n    templateUrl: 'edge.component.html',\n    styleUrls: ['edge.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class NoderEdgeComponent extends DestroyComponent {\n    @Input() model: EdgeModel;\n\n    @Input() generalProperties: GeneralPropertiesModel;\n\n    @Input() margins: MarginModel;\n\n    @Input() width: number;\n\n    @Input() parentSessionId: number;\n\n    @Input()\n    set type(val: EdgeType) {\n        this._type = val;\n        if (val === EdgeType.Header) {\n            this.editModeClass = 'header-edit-mode';\n            this.typeContainerPosition = 'top';\n        } else {\n            this.editModeClass = 'footer-edit-mode';\n            this.typeContainerPosition = 'bottom';\n        }\n    }\n    get type(): EdgeType {\n        return this._type;\n    }\n    private _type: EdgeType;\n\n    @HostBinding('attr.data-session-id')\n    sessionId: number;\n\n    edgeSession: SessionModel;\n\n    editModeClass: string;\n\n    typeContainerPosition: string;\n\n    get session(): EditSession {\n        return this.edgeSession.session;\n    }\n\n    get renderer(): Renderer | VirtualRenderer {\n        return this.edgeSession.renderer;\n    }\n\n    get height(): number {\n        return this.session.displayData.defaultVerticalData.contentHeight;\n    }\n\n    @ViewChild('container', { static: true }) container: ElementRef<HTMLElement>;\n\n    @ViewChild('locationType', { static: true }) typeContainer: ElementRef<HTMLElement>;\n\n    private _previousHeight: number;\n\n    constructor(private regulatorService: RegulatorService, private editorService: EditorService) {\n        super();\n    }\n\n    override ngOnDestroy(): void {\n        this.regulatorService.removeSession(this.sessionId);\n        super.ngOnDestroy();\n    }\n\n    initialize(): void {\n        this.edgeSession = this.regulatorService.addEdgeSession(this);\n        this.sessionId = this.edgeSession.sessionId;\n        this._previousHeight = this.height;\n        DomHelper.setStyle(this.container.nativeElement.style, 'overflow', 'hidden');\n        DomHelper.setStyle(this.typeContainer.nativeElement.style, 'visibility', 'hidden');\n        this.setTypeContainerPosition();\n        this.editorService.rendererUpdated$.pipe(takeUntil(this.destroy$)).subscribe(x => this.rendererUpdated(x));\n    }\n\n    enterEditMode(): void {\n        DomHelper.addCssClass(this.container.nativeElement, this.editModeClass);\n        DomHelper.setStyle(this.typeContainer.nativeElement.style, 'visibility', 'visible');\n    }\n\n    leaveEditMode(): void {\n        DomHelper.removeCssClass(this.container.nativeElement, this.editModeClass);\n        DomHelper.setStyle(this.typeContainer.nativeElement.style, 'visibility', 'hidden');\n    }\n\n    rendererUpdated(sessionId: number): void {\n        if (sessionId !== this.sessionId || this.height === this._previousHeight) {\n            return;\n        }\n\n        this.editorService.changedEdgeHeight(this.type);\n        this._previousHeight = this.height;\n        this.setTypeContainerPosition();\n    }\n\n    private setTypeContainerPosition(): void {\n        const renderedEdgeHeight = this.height > this.generalProperties.maxEdgeHeight ? this.generalProperties.maxEdgeHeight : this.height;\n        DomHelper.setStyle(this.typeContainer.nativeElement.style, this.typeContainerPosition, `${renderedEdgeHeight}px`);\n    }\n}\n","<div\n    #container\n    class=\"edit-container\"></div>\n<div\n    #locationType\n    class=\"location-type\"></div>\n"]}
99
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edge.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-noder/src/lib/editor/components/edges/edge.component.ts","../../../../../../../projects/ngx-noder/src/lib/editor/components/edges/edge.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, Input, ViewChild } from '@angular/core';\n\nimport { DestroyComponent } from '../shared/abstract/destroy.component';\nimport { DomHelper } from '../../execution/helpers/dom.helper';\nimport { EdgeModel } from '../../../models/generated/edge.model';\nimport { EdgeType } from './edge-type.enum';\nimport { EditorService } from '../../interaction/editor.service';\nimport { EditSession } from '../../execution/edit.session';\nimport { GeneralPropertiesModel } from '../../content/display-data/general-properties.model';\nimport { MarginModel } from '../../content/margin.model';\nimport { PageType } from './page-type.enum';\nimport { RegulatorService } from '../../execution/regulator.service';\nimport { Renderer } from '../../display/renderer';\nimport { SessionModel } from '../../execution/targeting/session.model';\nimport { VirtualRenderer } from '../../display/virtual.renderer';\n\n@Component({\n    selector: 'app-nod-edge',\n    templateUrl: 'edge.component.html',\n    styleUrls: ['edge.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class NoderEdgeComponent extends DestroyComponent {\n    @Input() model: EdgeModel;\n\n    @Input() generalProperties: GeneralPropertiesModel;\n\n    @Input() margins: MarginModel;\n\n    @Input() width: number;\n\n    @Input() parentSessionId: number;\n\n    @Input()\n    set type(val: EdgeType) {\n        this._type = val;\n        if (val === EdgeType.Header) {\n            this.editModeClass = 'header-edit-mode';\n            this.typeContainerPosition = 'top';\n        } else {\n            this.editModeClass = 'footer-edit-mode';\n            this.typeContainerPosition = 'bottom';\n        }\n    }\n    get type(): EdgeType {\n        return this._type;\n    }\n    private _type: EdgeType;\n\n    sessionId: number;\n\n    edgeSession: SessionModel;\n\n    editModeClass: string;\n\n    typeContainerPosition: string;\n\n    get session(): EditSession {\n        return this.edgeSession.session;\n    }\n\n    get renderer(): Renderer | VirtualRenderer {\n        return this.edgeSession.renderer;\n    }\n\n    get contentHeight(): number {\n        return this.session.displayData.defaultVerticalData.contentHeight;\n    }\n\n    @ViewChild('container', { static: true }) container: ElementRef<HTMLElement>;\n\n    @ViewChild('locationType', { static: true }) typeContainer: ElementRef<HTMLElement>;\n\n    private _height: number; // height of whole component used to track its changes\n\n    constructor(private regulatorService: RegulatorService, private editorService: EditorService) {\n        super();\n    }\n\n    override ngOnDestroy(): void {\n        this.session?.displayData.removeEventListener('pagesCountChanged', this.pagesCountChangedHandler);\n        this.regulatorService.removeSession(this.sessionId);\n        super.ngOnDestroy();\n    }\n\n    initialize(): void {\n        this.edgeSession = this.regulatorService.addEdgeSession(this);\n        this.sessionId = this.edgeSession.sessionId;\n        this.container.nativeElement.parentElement.setAttribute('data-session-id', `${this.sessionId}`);\n        DomHelper.setStyle(this.container.nativeElement.style, 'overflow', 'hidden');\n        DomHelper.setStyle(this.typeContainer.nativeElement.style, 'visibility', 'hidden');\n        this.applyHeight();\n        this.session.displayData.addEventListener('pagesCountChanged', this.pagesCountChangedHandler);\n    }\n\n    enterEditMode(): void {\n        DomHelper.addCssClass(this.container.nativeElement, this.editModeClass);\n        DomHelper.setStyle(this.typeContainer.nativeElement.style, 'visibility', 'visible');\n        this.editorService.changedEdge(this.sessionId);\n    }\n\n    leaveEditMode(): void {\n        DomHelper.removeCssClass(this.container.nativeElement, this.editModeClass);\n        DomHelper.setStyle(this.typeContainer.nativeElement.style, 'visibility', 'hidden');\n        this.editorService.changedEdge(this.sessionId);\n    }\n\n    private applyHeight(): void {\n        const maxHeight = this.generalProperties.maxEdgeHeight;\n        const height = this.contentHeight > maxHeight ? maxHeight : this.contentHeight;\n        DomHelper.setStyle(this.typeContainer.nativeElement.style, this.typeContainerPosition, `${height}px`);\n    }\n\n    private pagesCountChangedHandler = (event: { pageHeight: number }): void => {\n        if (this._height === event.pageHeight) {\n            return;\n        }\n\n        this._height = event.pageHeight;\n        this.applyHeight();\n        this.editorService.changedEdgeSize(this.type, this.model.pageType as PageType);\n    };\n}\n","<div\n    #container\n    class=\"edit-container\"></div>\n<div\n    #locationType\n    class=\"location-type\"></div>\n"]}
@@ -2,7 +2,6 @@ import { EdgeType } from './edge-type.enum';
2
2
  import { MarginModel } from '../../content/margin.model';
3
3
  import { NoderEdgeComponent } from './edge.component';
4
4
  import { PageType } from './page-type.enum';
5
- import { RenderChangesModel } from '../../display/render-changes.model';
6
5
  export class Edges {
7
6
  constructor(componentService, headers, footers, margins, pageWidth, parentSessionId, generalProperties) {
8
7
  this.componentService = componentService;
@@ -10,6 +9,7 @@ export class Edges {
10
9
  this.generalProperties = generalProperties;
11
10
  this.headersComponents = [];
12
11
  this.footersComponents = [];
12
+ this.isEdit = false;
13
13
  if (headers) {
14
14
  const headerMargins = new MarginModel({ ...margins, bottom: 0 });
15
15
  this.headersComponents = this.createComponents(headers, pageWidth, headerMargins, EdgeType.Header);
@@ -20,6 +20,14 @@ export class Edges {
20
20
  }
21
21
  this.setEdgeNameToComponents();
22
22
  }
23
+ getTypeBySessionId(sessionId) {
24
+ let component = this.headersComponents.find(x => x.instance.sessionId === sessionId);
25
+ if (component) {
26
+ return { type: EdgeType.Header, pageType: component.instance.model.pageType };
27
+ }
28
+ component = this.footersComponents.find(x => x.instance.sessionId === sessionId);
29
+ return { type: EdgeType.Footer, pageType: component.instance.model.pageType };
30
+ }
23
31
  getComponentByPage(page, type) {
24
32
  const components = type === EdgeType.Header ? this.headersComponents : this.footersComponents;
25
33
  return this.getComponent(components, page);
@@ -33,24 +41,32 @@ export class Edges {
33
41
  if (!component) {
34
42
  return 0;
35
43
  }
36
- return component.instance.height > this.generalProperties.maxEdgeHeight
44
+ return component.instance.contentHeight > this.generalProperties.maxEdgeHeight
37
45
  ? this.generalProperties.maxEdgeHeight
38
- : component.instance.height;
46
+ : component.instance.contentHeight;
47
+ }
48
+ getComponentHeight(instance) {
49
+ const height = instance.contentHeight;
50
+ return height > this.generalProperties.maxEdgeHeight ? this.generalProperties.maxEdgeHeight : height;
39
51
  }
40
- getComponentHeight(page, type) {
52
+ getComponentHeightByType(pageType, type) {
41
53
  const components = type === EdgeType.Header ? this.headersComponents : this.footersComponents;
42
- const component = this.getComponent(components, page);
43
- if (!component) {
44
- return 0;
45
- }
46
- return component.instance.height > this.generalProperties.maxEdgeHeight
47
- ? this.generalProperties.maxEdgeHeight
48
- : component.instance.height;
54
+ const height = components.find(x => x.instance.model.pageType === pageType)?.instance.contentHeight ?? 0;
55
+ return height > this.generalProperties.maxEdgeHeight ? this.generalProperties.maxEdgeHeight : height;
49
56
  }
50
- toggleEditMode(needEnable) {
57
+ toggleEditMode(isEdit) {
58
+ if (this.isEdit === isEdit) {
59
+ return;
60
+ }
61
+ this.isEdit = isEdit;
51
62
  const edgeComponents = [...this.headersComponents, ...this.footersComponents];
52
63
  for (let component of edgeComponents) {
53
- needEnable ? component.instance.enterEditMode() : component.instance.leaveEditMode();
64
+ if (isEdit) {
65
+ component.instance.enterEditMode();
66
+ }
67
+ else {
68
+ component.instance.leaveEditMode();
69
+ }
54
70
  }
55
71
  }
56
72
  getUniquePageTypes() {
@@ -87,7 +103,6 @@ export class Edges {
87
103
  generalProperties: this.generalProperties,
88
104
  parentSessionId: this.parentSessionId
89
105
  });
90
- componentRef.instance.renderer.renderChanges(new RenderChangesModel({ text: true }));
91
106
  resultComponents.push(componentRef);
92
107
  }
93
108
  return resultComponents;
@@ -124,4 +139,4 @@ export class Edges {
124
139
  return edgeName;
125
140
  }
126
141
  }
127
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edges.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-noder/src/lib/editor/components/edges/edges.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAE5C,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AACzD,OAAO,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AACtD,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AAExE,MAAM,OAAO,KAAK;IAKd,YACY,gBAAkC,EAC1C,OAAoB,EACpB,OAAoB,EACpB,OAAoB,EACpB,SAAiB,EACT,eAAuB,EACvB,iBAAyC;QANzC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAKlC,oBAAe,GAAf,eAAe,CAAQ;QACvB,sBAAiB,GAAjB,iBAAiB,CAAwB;QAXrD,sBAAiB,GAAuC,EAAE,CAAC;QAE3D,sBAAiB,GAAuC,EAAE,CAAC;QAWvD,IAAI,OAAO,EAAE;YACT,MAAM,aAAa,GAAG,IAAI,WAAW,CAAC,EAAE,GAAG,OAAO,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,CAAC;YACjE,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,QAAQ,CAAC,MAAM,CAAC,CAAC;SACtG;QAED,IAAI,OAAO,EAAE;YACT,MAAM,aAAa,GAAG,IAAI,WAAW,CAAC,EAAE,GAAG,OAAO,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;YAC9D,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,QAAQ,CAAC,MAAM,CAAC,CAAC;SACtG;QAED,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACnC,CAAC;IAED,kBAAkB,CAAC,IAAY,EAAE,IAAc;QAC3C,MAAM,UAAU,GAAG,IAAI,KAAK,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC;QAC9F,OAAO,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;IAC/C,CAAC;IAED,sBAAsB,CAAC,QAAkB,EAAE,IAAc;QACrD,MAAM,UAAU,GAAG,IAAI,KAAK,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC;QAC9F,OAAO,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,KAAK,QAAQ,CAAC,CAAC;IACxE,CAAC;IAED,4BAA4B,CAAC,QAAkB,EAAE,IAAc;QAC3D,MAAM,SAAS,GAAG,IAAI,CAAC,sBAAsB,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;QAC9D,IAAI,CAAC,SAAS,EAAE;YACZ,OAAO,CAAC,CAAC;SACZ;QAED,OAAO,SAAS,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,iBAAiB,CAAC,aAAa;YACnE,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,aAAa;YACtC,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC;IACpC,CAAC;IAED,kBAAkB,CAAC,IAAY,EAAE,IAAc;QAC3C,MAAM,UAAU,GAAG,IAAI,KAAK,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC;QAC9F,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;QACtD,IAAI,CAAC,SAAS,EAAE;YACZ,OAAO,CAAC,CAAC;SACZ;QAED,OAAO,SAAS,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,iBAAiB,CAAC,aAAa;YACnE,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,aAAa;YACtC,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC;IACpC,CAAC;IAED,cAAc,CAAC,UAAmB;QAC9B,MAAM,cAAc,GAAG,CAAC,GAAG,IAAI,CAAC,iBAAiB,EAAE,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAC9E,KAAK,IAAI,SAAS,IAAI,cAAc,EAAE;YAClC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,aAAa,EAAE,CAAC;SACxF;IACL,CAAC;IAED,kBAAkB;QACd,MAAM,cAAc,GAAG,CAAC,GAAG,IAAI,CAAC,iBAAiB,EAAE,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAC9E,OAAO,CAAC,GAAG,IAAI,GAAG,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;IAC5E,CAAC;IAEO,gBAAgB,CACpB,UAAuB,EACvB,SAAiB,EACjB,OAAoB,EACpB,IAAc;QAEd,MAAM,gBAAgB,GAAG,EAAE,CAAC;QAC5B,MAAM,YAAY,GAAG,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,KAAK,QAAQ,CAAC,KAAK,CAAC,CAAC;QAC/E,KAAK,IAAI,KAAK,IAAI,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YACvC,IAAI,YAAY,EAAE;gBACd,IAAI,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,KAAK;oBAAE,OAAO,CAAC,CAAC,CAAC;gBAC7C,IAAI,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,KAAK;oBAAE,OAAO,CAAC,CAAC;aAC/C;iBAAM;gBACH,IAAI,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,OAAO;oBAAE,OAAO,CAAC,CAAC,CAAC;gBAC/C,IAAI,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,OAAO;oBAAE,OAAO,CAAC,CAAC;aACjD;YACD,IAAI,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,IAAI;gBAAE,OAAO,CAAC,CAAC,CAAC;YAC5C,IAAI,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,IAAI;gBAAE,OAAO,CAAC,CAAC;YAC3C,OAAO,CAAC,CAAC;QACb,CAAC,CAAC,EAAE;YACA,MAAM,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,kBAAkB,EAAE;gBAC7E,KAAK;gBACL,OAAO;gBACP,IAAI;gBACJ,KAAK,EAAE,SAAS;gBAChB,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;gBACzC,eAAe,EAAE,IAAI,CAAC,eAAe;aACxC,CAAC,CAAC;YACH,YAAY,CAAC,QAAQ,CAAC,QAAQ,CAAC,aAAa,CAAC,IAAI,kBAAkB,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;YACrF,gBAAgB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;SACvC;QAED,OAAO,gBAAgB,CAAC;IAC5B,CAAC;IAEO,YAAY,CAAC,cAAkD,EAAE,IAAY;QACjF,MAAM,gBAAgB,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,KAAK,QAAQ,CAAC,OAAO,CAAC,CAAC;QAClG,IAAI,IAAI,KAAK,CAAC,EAAE;YACZ,OAAO,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,KAAK,QAAQ,CAAC,KAAK,CAAC,IAAI,gBAAgB,CAAC;SACrG;QAED,MAAM,UAAU,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC;QACrE,OAAO,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,KAAK,UAAU,CAAC,IAAI,gBAAgB,CAAC;IAClG,CAAC;IAEO,uBAAuB;QAC3B,MAAM,cAAc,GAAG,CAAC,GAAG,IAAI,CAAC,iBAAiB,EAAE,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAC9E,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE;YACxB,OAAO;SACV;QAED,MAAM,gBAAgB,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,KAAK,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC/F,KAAK,IAAI,SAAS,IAAI,cAAc,EAAE;YAClC,SAAS,CAAC,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,SAAS,GAAG,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,QAAQ,EAAE,gBAAgB,CAAC,CAAC;SAC3H;IACL,CAAC;IAEO,iBAAiB,CAAC,SAA6B,EAAE,gBAAyB;QAC9E,IAAI,QAAQ,GAAG,SAAS,CAAC,IAAI,KAAK,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC;QACxE,IAAI,SAAS,CAAC,KAAK,CAAC,QAAQ,KAAK,QAAQ,CAAC,KAAK,EAAE;YAC7C,QAAQ,GAAG,cAAc,QAAQ,EAAE,CAAC;SACvC;aAAM,IAAI,SAAS,CAAC,KAAK,CAAC,QAAQ,KAAK,QAAQ,CAAC,IAAI,EAAE;YACnD,QAAQ,GAAG,cAAc,QAAQ,EAAE,CAAC;SACvC;aAAM,IAAI,SAAS,CAAC,KAAK,CAAC,QAAQ,KAAK,QAAQ,CAAC,OAAO,IAAI,gBAAgB,EAAE;YAC1E,QAAQ,GAAG,aAAa,QAAQ,EAAE,CAAC;SACtC;QAED,OAAO,QAAQ,CAAC;IACpB,CAAC;CACJ","sourcesContent":["import { ComponentRef } from '@angular/core';\n\nimport { ComponentService } from '../shared/services/component.service';\nimport { EdgeModel } from '../../../models/generated/edge.model';\nimport { EdgeType } from './edge-type.enum';\nimport { GeneralPropertiesModel } from '../../content/display-data/general-properties.model';\nimport { MarginModel } from '../../content/margin.model';\nimport { NoderEdgeComponent } from './edge.component';\nimport { PageType } from './page-type.enum';\nimport { RenderChangesModel } from '../../display/render-changes.model';\n\nexport class Edges {\n    headersComponents: ComponentRef<NoderEdgeComponent>[] = [];\n\n    footersComponents: ComponentRef<NoderEdgeComponent>[] = [];\n\n    constructor(\n        private componentService: ComponentService,\n        headers: EdgeModel[],\n        footers: EdgeModel[],\n        margins: MarginModel,\n        pageWidth: number,\n        private parentSessionId: number,\n        private generalProperties: GeneralPropertiesModel\n    ) {\n        if (headers) {\n            const headerMargins = new MarginModel({ ...margins, bottom: 0 });\n            this.headersComponents = this.createComponents(headers, pageWidth, headerMargins, EdgeType.Header);\n        }\n\n        if (footers) {\n            const footerMargins = new MarginModel({ ...margins, top: 0 });\n            this.footersComponents = this.createComponents(footers, pageWidth, footerMargins, EdgeType.Footer);\n        }\n\n        this.setEdgeNameToComponents();\n    }\n\n    getComponentByPage(page: number, type: EdgeType): ComponentRef<NoderEdgeComponent> {\n        const components = type === EdgeType.Header ? this.headersComponents : this.footersComponents;\n        return this.getComponent(components, page);\n    }\n\n    getComponentByPageType(pageType: PageType, type: EdgeType): ComponentRef<NoderEdgeComponent> {\n        const components = type === EdgeType.Header ? this.headersComponents : this.footersComponents;\n        return components.find(x => x.instance.model.pageType === pageType);\n    }\n\n    getComponentHeightByPageType(pageType: PageType, type: EdgeType): number {\n        const component = this.getComponentByPageType(pageType, type);\n        if (!component) {\n            return 0;\n        }\n\n        return component.instance.height > this.generalProperties.maxEdgeHeight\n            ? this.generalProperties.maxEdgeHeight\n            : component.instance.height;\n    }\n\n    getComponentHeight(page: number, type: EdgeType): number {\n        const components = type === EdgeType.Header ? this.headersComponents : this.footersComponents;\n        const component = this.getComponent(components, page);\n        if (!component) {\n            return 0;\n        }\n\n        return component.instance.height > this.generalProperties.maxEdgeHeight\n            ? this.generalProperties.maxEdgeHeight\n            : component.instance.height;\n    }\n\n    toggleEditMode(needEnable: boolean) {\n        const edgeComponents = [...this.headersComponents, ...this.footersComponents];\n        for (let component of edgeComponents) {\n            needEnable ? component.instance.enterEditMode() : component.instance.leaveEditMode();\n        }\n    }\n\n    getUniquePageTypes(): PageType[] {\n        const edgeComponents = [...this.headersComponents, ...this.footersComponents];\n        return [...new Set(edgeComponents.map(x => x.instance.model.pageType))];\n    }\n\n    private createComponents(\n        edgeModels: EdgeModel[],\n        pageWidth: number,\n        margins: MarginModel,\n        type: EdgeType\n    ): ComponentRef<NoderEdgeComponent>[] {\n        const resultComponents = [];\n        const hasFirstEdge = edgeModels.some(edge => edge.pageType === PageType.First);\n        for (let model of edgeModels.sort((x, y) => {\n            if (hasFirstEdge) {\n                if (x.pageType === PageType.First) return -1;\n                if (y.pageType === PageType.First) return 1;\n            } else {\n                if (x.pageType === PageType.Default) return -1;\n                if (y.pageType === PageType.Default) return 1;\n            }\n            if (x.pageType === PageType.Even) return -1;\n            if (y.pageType === PageType.Even) return 1;\n            return 0;\n        })) {\n            const componentRef = this.componentService.generateComponent(NoderEdgeComponent, {\n                model,\n                margins,\n                type,\n                width: pageWidth,\n                generalProperties: this.generalProperties,\n                parentSessionId: this.parentSessionId\n            });\n            componentRef.instance.renderer.renderChanges(new RenderChangesModel({ text: true }));\n            resultComponents.push(componentRef);\n        }\n\n        return resultComponents;\n    }\n\n    private getComponent(edgeComponents: ComponentRef<NoderEdgeComponent>[], page: number): ComponentRef<NoderEdgeComponent> {\n        const defaultComponent = edgeComponents.find(x => x.instance.model.pageType === PageType.Default);\n        if (page === 1) {\n            return edgeComponents.find(x => x.instance.model.pageType === PageType.First) || defaultComponent;\n        }\n\n        const targetType = page % 2 === 0 ? PageType.Even : PageType.Default;\n        return edgeComponents.find(x => x.instance.model.pageType === targetType) || defaultComponent;\n    }\n\n    private setEdgeNameToComponents(): void {\n        const edgeComponents = [...this.headersComponents, ...this.footersComponents];\n        if (!edgeComponents.length) {\n            return;\n        }\n\n        const isEvenEdgesExist = edgeComponents.some(x => x.instance.model.pageType === PageType.Even);\n        for (let component of edgeComponents) {\n            component.instance.typeContainer.nativeElement.innerText = this.getEdgeNameByType(component.instance, isEvenEdgesExist);\n        }\n    }\n\n    private getEdgeNameByType(component: NoderEdgeComponent, isEvenEdgesExist: boolean): string {\n        let edgeName = component.type === EdgeType.Header ? 'Header' : 'Footer';\n        if (component.model.pageType === PageType.First) {\n            edgeName = `First Page ${edgeName}`;\n        } else if (component.model.pageType === PageType.Even) {\n            edgeName = `Even Pages ${edgeName}`;\n        } else if (component.model.pageType === PageType.Default && isEvenEdgesExist) {\n            edgeName = `Odd Pages ${edgeName}`;\n        }\n\n        return edgeName;\n    }\n}\n"]}
142
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edges.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-noder/src/lib/editor/components/edges/edges.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentRef } from '@angular/core';\n\nimport { ComponentService } from '../shared/services/component.service';\nimport { EdgeModel } from '../../../models/generated/edge.model';\nimport { EdgeType } from './edge-type.enum';\nimport { GeneralPropertiesModel } from '../../content/display-data/general-properties.model';\nimport { MarginModel } from '../../content/margin.model';\nimport { NoderEdgeComponent } from './edge.component';\nimport { PageType } from './page-type.enum';\n\nexport class Edges {\n    headersComponents: ComponentRef<NoderEdgeComponent>[] = [];\n\n    footersComponents: ComponentRef<NoderEdgeComponent>[] = [];\n\n    isEdit = false;\n\n    constructor(\n        private componentService: ComponentService,\n        headers: EdgeModel[],\n        footers: EdgeModel[],\n        margins: MarginModel,\n        pageWidth: number,\n        private parentSessionId: number,\n        private generalProperties: GeneralPropertiesModel\n    ) {\n        if (headers) {\n            const headerMargins = new MarginModel({ ...margins, bottom: 0 });\n            this.headersComponents = this.createComponents(headers, pageWidth, headerMargins, EdgeType.Header);\n        }\n\n        if (footers) {\n            const footerMargins = new MarginModel({ ...margins, top: 0 });\n            this.footersComponents = this.createComponents(footers, pageWidth, footerMargins, EdgeType.Footer);\n        }\n\n        this.setEdgeNameToComponents();\n    }\n\n    getTypeBySessionId(sessionId: number): { type: EdgeType; pageType: PageType } {\n        let component = this.headersComponents.find(x => x.instance.sessionId === sessionId);\n        if (component) {\n            return { type: EdgeType.Header, pageType: component.instance.model.pageType };\n        }\n        component = this.footersComponents.find(x => x.instance.sessionId === sessionId);\n        return { type: EdgeType.Footer, pageType: component.instance.model.pageType };\n    }\n\n    getComponentByPage(page: number, type: EdgeType): ComponentRef<NoderEdgeComponent> {\n        const components = type === EdgeType.Header ? this.headersComponents : this.footersComponents;\n        return this.getComponent(components, page);\n    }\n\n    getComponentByPageType(pageType: PageType, type: EdgeType): ComponentRef<NoderEdgeComponent> {\n        const components = type === EdgeType.Header ? this.headersComponents : this.footersComponents;\n        return components.find(x => x.instance.model.pageType === pageType);\n    }\n\n    getComponentHeightByPageType(pageType: PageType, type: EdgeType): number {\n        const component = this.getComponentByPageType(pageType, type);\n        if (!component) {\n            return 0;\n        }\n\n        return component.instance.contentHeight > this.generalProperties.maxEdgeHeight\n            ? this.generalProperties.maxEdgeHeight\n            : component.instance.contentHeight;\n    }\n\n    getComponentHeight(instance: NoderEdgeComponent): number {\n        const height = instance.contentHeight;\n        return height > this.generalProperties.maxEdgeHeight ? this.generalProperties.maxEdgeHeight : height;\n    }\n\n    getComponentHeightByType(pageType: PageType, type: EdgeType): number {\n        const components = type === EdgeType.Header ? this.headersComponents : this.footersComponents;\n        const height = components.find(x => x.instance.model.pageType === pageType)?.instance.contentHeight ?? 0;\n        return height > this.generalProperties.maxEdgeHeight ? this.generalProperties.maxEdgeHeight : height;\n    }\n\n    toggleEditMode(isEdit: boolean): void {\n        if (this.isEdit === isEdit) {\n            return;\n        }\n        this.isEdit = isEdit;\n        const edgeComponents = [...this.headersComponents, ...this.footersComponents];\n        for (let component of edgeComponents) {\n            if (isEdit) {\n                component.instance.enterEditMode();\n            } else {\n                component.instance.leaveEditMode();\n            }\n        }\n    }\n\n    getUniquePageTypes(): PageType[] {\n        const edgeComponents = [...this.headersComponents, ...this.footersComponents];\n        return [...new Set(edgeComponents.map(x => x.instance.model.pageType))];\n    }\n\n    private createComponents(\n        edgeModels: EdgeModel[],\n        pageWidth: number,\n        margins: MarginModel,\n        type: EdgeType\n    ): ComponentRef<NoderEdgeComponent>[] {\n        const resultComponents = [];\n        const hasFirstEdge = edgeModels.some(edge => edge.pageType === PageType.First);\n        for (let model of edgeModels.sort((x, y) => {\n            if (hasFirstEdge) {\n                if (x.pageType === PageType.First) return -1;\n                if (y.pageType === PageType.First) return 1;\n            } else {\n                if (x.pageType === PageType.Default) return -1;\n                if (y.pageType === PageType.Default) return 1;\n            }\n            if (x.pageType === PageType.Even) return -1;\n            if (y.pageType === PageType.Even) return 1;\n            return 0;\n        })) {\n            const componentRef = this.componentService.generateComponent(NoderEdgeComponent, {\n                model,\n                margins,\n                type,\n                width: pageWidth,\n                generalProperties: this.generalProperties,\n                parentSessionId: this.parentSessionId\n            });\n            resultComponents.push(componentRef);\n        }\n\n        return resultComponents;\n    }\n\n    private getComponent(edgeComponents: ComponentRef<NoderEdgeComponent>[], page: number): ComponentRef<NoderEdgeComponent> {\n        const defaultComponent = edgeComponents.find(x => x.instance.model.pageType === PageType.Default);\n        if (page === 1) {\n            return edgeComponents.find(x => x.instance.model.pageType === PageType.First) || defaultComponent;\n        }\n\n        const targetType = page % 2 === 0 ? PageType.Even : PageType.Default;\n        return edgeComponents.find(x => x.instance.model.pageType === targetType) || defaultComponent;\n    }\n\n    private setEdgeNameToComponents(): void {\n        const edgeComponents = [...this.headersComponents, ...this.footersComponents];\n        if (!edgeComponents.length) {\n            return;\n        }\n\n        const isEvenEdgesExist = edgeComponents.some(x => x.instance.model.pageType === PageType.Even);\n        for (let component of edgeComponents) {\n            component.instance.typeContainer.nativeElement.innerText = this.getEdgeNameByType(component.instance, isEvenEdgesExist);\n        }\n    }\n\n    private getEdgeNameByType(component: NoderEdgeComponent, isEvenEdgesExist: boolean): string {\n        let edgeName = component.type === EdgeType.Header ? 'Header' : 'Footer';\n        if (component.model.pageType === PageType.First) {\n            edgeName = `First Page ${edgeName}`;\n        } else if (component.model.pageType === PageType.Even) {\n            edgeName = `Even Pages ${edgeName}`;\n        } else if (component.model.pageType === PageType.Default && isEvenEdgesExist) {\n            edgeName = `Odd Pages ${edgeName}`;\n        }\n\n        return edgeName;\n    }\n}\n"]}
@@ -35,7 +35,7 @@ export class NoderImageComponent extends BaseNoderComponent {
35
35
  const fileSource = URL.createObjectURL(x);
36
36
  const image = this.createImage(fileSource);
37
37
  this.elementRef.nativeElement.appendChild(image);
38
- this.editorService.rendererUpdated(this.sessionId);
38
+ this.editorService.imageLoaded(this.sessionId);
39
39
  });
40
40
  }
41
41
  onResizeEnd(size) {
@@ -85,4 +85,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
85
85
  type: Component,
86
86
  args: [{ selector: 'app-nod-image', changeDetection: ChangeDetectionStrategy.OnPush, template: "<app-nod-resizer\n *ngIf=\"isFocused\"\n class=\"resizer\"\n [isDisabled]=\"isViewOnly$ | async\"\n [size]=\"size\"\n (resizeEnd)=\"onResizeEnd($event)\" />\n", styles: [":host{position:relative;outline:none}.resizer{position:absolute;z-index:1}\n"] }]
87
87
  }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.ImageApiService }, { type: i2.EditorService }] });
88
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-noder/src/lib/editor/components/image/components/image.component.ts","../../../../../../../../projects/ngx-noder/src/lib/editor/components/image/components/image.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAc,MAAM,eAAe,CAAC;AAG/E,OAAO,EAAE,kBAAkB,EAAE,MAAM,sCAAsC,CAAC;AAG1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,6DAA6D,CAAC;AAEhG,OAAO,EAAE,aAAa,EAAE,MAAM,yCAAyC,CAAC;;;;;;AASxE,MAAM,OAAO,mBAAoB,SAAQ,kBAAkB;IACvD,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC;IAC1C,CAAC;IAED,IAAI,KAAK;QACL,OAAO,IAAI,CAAC,OAAqB,CAAC;IACtC,CAAC;IACD,IAAI,KAAK,CAAC,GAAe;QACrB,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC;IACvB,CAAC;IAED,IAAI,IAAI;QACJ,OAAO,EAAE,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC;IACxD,CAAC;IAMD,YAAsB,UAAmC,EAAU,UAA2B,EAAU,aAA4B;QAChI,KAAK,EAAE,CAAC;QADU,eAAU,GAAV,UAAU,CAAyB;QAAU,eAAU,GAAV,UAAU,CAAiB;QAAU,kBAAa,GAAb,aAAa,CAAe;QAJ5H,aAAQ,GAAG,KAAK,CAAC;IAMzB,CAAC;IAED,UAAU;QACN,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC;QAC3D,IAAI,CAAC,OAAO,GAAG,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC;QAC3F,IAAI,CAAC,MAAM,GAAG,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC;QACzF,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YACvC,MAAM,UAAU,GAAG,GAAG,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;YAC1C,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;YAC3C,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YACjD,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACvD,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW,CAAC,IAAU;QAClB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAClB,MAAM,YAAY,GAAG,EAAE,GAAG,IAAI,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC;QAC/E,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,YAAY,CAAC,CAAC;IACtD,CAAC;IAED,MAAM,CAAC,IAAU;QACb,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC;QACzB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC;QAC3B,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QACjE,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC5B,CAAC;IAEQ,KAAK;QACV,IAAI,CAAC,YAAY,GAAG,IAAI,iBAAiB,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;QACpE,KAAK,CAAC,KAAK,EAAE,CAAC;IAClB,CAAC;IAEQ,IAAI;QACT,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,CAAC;QAC7B,KAAK,CAAC,IAAI,EAAE,CAAC;IACjB,CAAC;IAEQ,WAAW;QAChB,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,CAAC;QAC7B,KAAK,CAAC,WAAW,EAAE,CAAC;IACxB,CAAC;IAEO,WAAW,CAAC,UAAkB;QAClC,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9C,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC;QAC5B,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC;QAC9B,OAAO,CAAC,GAAG,GAAG,UAAU,CAAC;QACzB,OAAO,OAAO,CAAC;IACnB,CAAC;IAEO,WAAW,CAAC,IAAU;QAC1B,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACjE,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QACzB,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;IAC/B,CAAC;IAEO,YAAY,CAAC,IAAU;QAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QACpE,KAAK,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,IAAI,CAAC,KAAK,IAAI,CAAC;QACtC,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,IAAI,CAAC;IAC5C,CAAC;+GAlFQ,mBAAmB;mGAAnB,mBAAmB,4ECjBhC,+KAMA;;4FDWa,mBAAmB;kBAN/B,SAAS;+BACI,eAAe,mBAGR,uBAAuB,CAAC,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef } from '@angular/core';\nimport { Observable } from 'rxjs';\n\nimport { BaseNoderComponent } from '../../shared/abstract/base.component';\nimport { EditorService } from '../../../interaction/editor.service';\nimport { ImageApiService } from '../../../components/image/image-api.service';\nimport { ImageInputHandler } from '../../../components/image/input-handler/image-input.handler';\nimport { ImageModel } from '../../../../models/generated/image.model';\nimport { ScalingHelper } from '../../../content/helpers/scaling.helper';\nimport { Size } from '../../../components/image/size';\n\n@Component({\n    selector: 'app-nod-image',\n    templateUrl: './image.component.html',\n    styleUrls: ['./image.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class NoderImageComponent extends BaseNoderComponent {\n    get isViewOnly$(): Observable<boolean> {\n        return this.editorService.isViewOnly$;\n    }\n\n    get image(): ImageModel {\n        return this.content as ImageModel;\n    }\n    set image(val: ImageModel) {\n        this.content = val;\n    }\n\n    get size(): Size {\n        return { width: this._width, height: this._height };\n    }\n\n    private isCanvas = false;\n\n    private inputHandler: ImageInputHandler;\n\n    constructor(protected elementRef: ElementRef<HTMLElement>, private apiService: ImageApiService, private editorService: EditorService) {\n        super();\n    }\n\n    initialize(): void {\n        const url = this.image.content?.replace('/api/', '') ?? '';\n        this._height = ScalingHelper.scale(this.image.height, this.generalProperties.scalingRatio);\n        this._width = ScalingHelper.scale(this.image.width, this.generalProperties.scalingRatio);\n        this.apiService.getFile(url).subscribe(x => {\n            const fileSource = URL.createObjectURL(x);\n            const image = this.createImage(fileSource);\n            this.elementRef.nativeElement.appendChild(image);\n            this.editorService.rendererUpdated(this.sessionId);\n        });\n    }\n\n    onResizeEnd(size: Size): void {\n        this.resize(size);\n        const resizedImage = { ...this.image, width: size.width, height: size.height };\n        this.editorService.changeImageStyle(resizedImage);\n    }\n\n    resize(size: Size): void {\n        this._width = size.width;\n        this._height = size.height;\n        this.isCanvas ? this.resizeCanvas(size) : this.resizeImage(size);\n        this.cdr.markForCheck();\n    }\n\n    override focus(): void {\n        this.inputHandler = new ImageInputHandler(this.editorService, this);\n        super.focus();\n    }\n\n    override blur(): void {\n        this.inputHandler?.destroy();\n        super.blur();\n    }\n\n    override ngOnDestroy(): void {\n        this.inputHandler?.destroy();\n        super.ngOnDestroy();\n    }\n\n    private createImage(fileSource: string): HTMLImageElement {\n        const imageEl = document.createElement('img');\n        imageEl.width = this._width;\n        imageEl.height = this._height;\n        imageEl.src = fileSource;\n        return imageEl;\n    }\n\n    private resizeImage(size: Size): void {\n        const image = this.elementRef.nativeElement.querySelector('img');\n        image.width = size.width;\n        image.height = size.height;\n    }\n\n    private resizeCanvas(size: Size): void {\n        const image = this.elementRef.nativeElement.querySelector('canvas');\n        image.style.width = `${size.width}px`;\n        image.style.height = `${size.height}px`;\n    }\n}\n","<app-nod-resizer\n    *ngIf=\"isFocused\"\n    class=\"resizer\"\n    [isDisabled]=\"isViewOnly$ | async\"\n    [size]=\"size\"\n    (resizeEnd)=\"onResizeEnd($event)\" />\n"]}
88
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-noder/src/lib/editor/components/image/components/image.component.ts","../../../../../../../../projects/ngx-noder/src/lib/editor/components/image/components/image.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef } from '@angular/core';\nimport { Observable } from 'rxjs';\n\nimport { BaseNoderComponent } from '../../shared/abstract/base.component';\nimport { EditorService } from '../../../interaction/editor.service';\nimport { ImageApiService } from '../../../components/image/image-api.service';\nimport { ImageInputHandler } from '../../../components/image/input-handler/image-input.handler';\nimport { ImageModel } from '../../../../models/generated/image.model';\nimport { ScalingHelper } from '../../../content/helpers/scaling.helper';\nimport { Size } from '../../../components/image/size';\n\n@Component({\n    selector: 'app-nod-image',\n    templateUrl: './image.component.html',\n    styleUrls: ['./image.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class NoderImageComponent extends BaseNoderComponent {\n    get isViewOnly$(): Observable<boolean> {\n        return this.editorService.isViewOnly$;\n    }\n\n    get image(): ImageModel {\n        return this.content as ImageModel;\n    }\n    set image(val: ImageModel) {\n        this.content = val;\n    }\n\n    get size(): Size {\n        return { width: this._width, height: this._height };\n    }\n\n    private isCanvas = false;\n\n    private inputHandler: ImageInputHandler;\n\n    constructor(protected elementRef: ElementRef<HTMLElement>, private apiService: ImageApiService, private editorService: EditorService) {\n        super();\n    }\n\n    initialize(): void {\n        const url = this.image.content?.replace('/api/', '') ?? '';\n        this._height = ScalingHelper.scale(this.image.height, this.generalProperties.scalingRatio);\n        this._width = ScalingHelper.scale(this.image.width, this.generalProperties.scalingRatio);\n        this.apiService.getFile(url).subscribe(x => {\n            const fileSource = URL.createObjectURL(x);\n            const image = this.createImage(fileSource);\n            this.elementRef.nativeElement.appendChild(image);\n            this.editorService.imageLoaded(this.sessionId);\n        });\n    }\n\n    onResizeEnd(size: Size): void {\n        this.resize(size);\n        const resizedImage = { ...this.image, width: size.width, height: size.height };\n        this.editorService.changeImageStyle(resizedImage);\n    }\n\n    resize(size: Size): void {\n        this._width = size.width;\n        this._height = size.height;\n        this.isCanvas ? this.resizeCanvas(size) : this.resizeImage(size);\n        this.cdr.markForCheck();\n    }\n\n    override focus(): void {\n        this.inputHandler = new ImageInputHandler(this.editorService, this);\n        super.focus();\n    }\n\n    override blur(): void {\n        this.inputHandler?.destroy();\n        super.blur();\n    }\n\n    override ngOnDestroy(): void {\n        this.inputHandler?.destroy();\n        super.ngOnDestroy();\n    }\n\n    private createImage(fileSource: string): HTMLImageElement {\n        const imageEl = document.createElement('img');\n        imageEl.width = this._width;\n        imageEl.height = this._height;\n        imageEl.src = fileSource;\n        return imageEl;\n    }\n\n    private resizeImage(size: Size): void {\n        const image = this.elementRef.nativeElement.querySelector('img');\n        image.width = size.width;\n        image.height = size.height;\n    }\n\n    private resizeCanvas(size: Size): void {\n        const image = this.elementRef.nativeElement.querySelector('canvas');\n        image.style.width = `${size.width}px`;\n        image.style.height = `${size.height}px`;\n    }\n}\n","<app-nod-resizer\n    *ngIf=\"isFocused\"\n    class=\"resizer\"\n    [isDisabled]=\"isViewOnly$ | async\"\n    [size]=\"size\"\n    (resizeEnd)=\"onResizeEnd($event)\" />\n"]}
@@ -22,7 +22,7 @@ export class ImageInputHandler {
22
22
  return;
23
23
  }
24
24
  const keyCombination = this.getKeyCombination(event);
25
- if (this.undoRedoActions[keyCombination] && !this.editorService.isViewOnly) {
25
+ if (this.undoRedoActions[keyCombination]) {
26
26
  this.undoRedoActions[keyCombination]();
27
27
  event.preventDefault();
28
28
  return;
@@ -52,4 +52,4 @@ export class ImageInputHandler {
52
52
  this.editorService.blurCustomComponent();
53
53
  }
54
54
  }
55
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UtaW5wdXQuaGFuZGxlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1ub2Rlci9zcmMvbGliL2VkaXRvci9jb21wb25lbnRzL2ltYWdlL2lucHV0LWhhbmRsZXIvaW1hZ2UtaW5wdXQuaGFuZGxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFnQixNQUFNLE1BQU0sQ0FBQztBQUsvQyxNQUFNLE9BQU8saUJBQWlCO0lBUzFCLFlBQTZCLGFBQTRCLEVBQW1CLEtBQTBCO1FBQXpFLGtCQUFhLEdBQWIsYUFBYSxDQUFlO1FBQW1CLFVBQUssR0FBTCxLQUFLLENBQXFCO1FBUjdGLDBCQUFxQixHQUFHLGVBQWUsQ0FBQztRQUVoQyxvQkFBZSxHQUFrQyxFQUFFLENBQUM7UUFPakUsSUFBSSxDQUFDLHdCQUF3QixHQUFHLFNBQVMsQ0FBZ0IsUUFBUSxFQUFFLFNBQVMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztRQUN4SCxJQUFJLENBQUMsaUJBQWlCLEdBQUcsU0FBUyxDQUFnQixRQUFRLEVBQUUsT0FBTyxDQUFDLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsTUFBcUIsQ0FBQyxDQUFDLENBQUM7UUFDbkksSUFBSSxDQUFDLG1CQUFtQixFQUFFLENBQUM7SUFDL0IsQ0FBQztJQUVELE9BQU87UUFDSCxJQUFJLENBQUMsd0JBQXdCLEVBQUUsV0FBVyxFQUFFLENBQUM7UUFDN0MsSUFBSSxDQUFDLGlCQUFpQixFQUFFLFdBQVcsRUFBRSxDQUFDO0lBQzFDLENBQUM7SUFFTyxTQUFTLENBQUMsS0FBb0I7UUFDbEMsSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDLFVBQVUsRUFBRTtZQUMvQixPQUFPO1NBQ1Y7UUFFRCxJQUFJLENBQUMsV0FBVyxFQUFFLFFBQVEsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDOUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQztZQUN2RCxPQUFPO1NBQ1Y7UUFFRCxNQUFNLGNBQWMsR0FBRyxJQUFJLENBQUMsaUJBQWlCLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDckQsSUFBSSxJQUFJLENBQUMsZUFBZSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxVQUFVLEVBQUU7WUFDeEUsSUFBSSxDQUFDLGVBQWUsQ0FBQyxjQUFjLENBQUMsRUFBRSxDQUFDO1lBQ3ZDLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztZQUN2QixPQUFPO1NBQ1Y7UUFFRCxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sSUFBSSxLQUFLLENBQUMsR0FBRyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7WUFDaEcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1NBQzVDO0lBQ0wsQ0FBQztJQUVPLGlCQUFpQixDQUFDLEtBQW9CO1FBQzFDLElBQUksTUFBTSxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBQzdDLE9BQU8sS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsR0FBRyxNQUFNLFFBQVEsS0FBSyxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7SUFDOUQsQ0FBQztJQUVPLG1CQUFtQjtRQUN2QixJQUFJLENBQUMsZUFBZSxDQUFDLFdBQVcsQ0FBQyxHQUFHLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDcEUsSUFBSSxDQUFDLGVBQWUsQ0FBQyxjQUFjLENBQUMsR0FBRyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3ZFLElBQUksQ0FBQyxlQUFlLENBQUMsV0FBVyxDQUFDLEdBQUcsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUNwRSxJQUFJLENBQUMsZUFBZSxDQUFDLGNBQWMsQ0FBQyxHQUFHLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDM0UsQ0FBQztJQUVPLE9BQU8sQ0FBQyxPQUFvQjtRQUNoQyxJQUFJLGNBQWMsR0FBRyxPQUFPLENBQUM7UUFDN0IsT0FBTyxjQUFjLEVBQUU7WUFDbkIsSUFBSSxjQUFjLENBQUMsT0FBTyxLQUFLLElBQUksQ0FBQyxxQkFBcUIsRUFBRTtnQkFDdkQsT0FBTzthQUNWO1lBQ0QsY0FBYyxHQUFHLGNBQWMsQ0FBQyxhQUFhLENBQUM7U0FDakQ7UUFDRCxJQUFJLENBQUMsYUFBYSxDQUFDLG1CQUFtQixFQUFFLENBQUM7SUFDN0MsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZnJvbUV2ZW50LCBTdWJzY3JpcHRpb24gfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHsgRWRpdG9yU2VydmljZSB9IGZyb20gJy4uLy4uLy4uL2ludGVyYWN0aW9uL2VkaXRvci5zZXJ2aWNlJztcbmltcG9ydCB7IE5vZGVySW1hZ2VDb21wb25lbnQgfSBmcm9tICcuLi9jb21wb25lbnRzL2ltYWdlLmNvbXBvbmVudCc7XG5cbmV4cG9ydCBjbGFzcyBJbWFnZUlucHV0SGFuZGxlciB7XG4gICAgcmVhZG9ubHkgaW1hZ2VDb21wb25lbnRUYWdOYW1lID0gJ0FQUC1OT0QtSU1BR0UnO1xuXG4gICAgcHJpdmF0ZSByZWFkb25seSB1bmRvUmVkb0FjdGlvbnM6IHsgW2tleTogc3RyaW5nXTogKCkgPT4gdm9pZCB9ID0ge307XG5cbiAgICBwcml2YXRlIHJlYWRvbmx5IGltYWdlS2V5RG93blN1YnNjcmlwdGlvbjogU3Vic2NyaXB0aW9uO1xuXG4gICAgcHJpdmF0ZSByZWFkb25seSBjbGlja1N1YnNjcmlwdGlvbjogU3Vic2NyaXB0aW9uO1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBlZGl0b3JTZXJ2aWNlOiBFZGl0b3JTZXJ2aWNlLCBwcml2YXRlIHJlYWRvbmx5IGltYWdlOiBOb2RlckltYWdlQ29tcG9uZW50KSB7XG4gICAgICAgIHRoaXMuaW1hZ2VLZXlEb3duU3Vic2NyaXB0aW9uID0gZnJvbUV2ZW50PEtleWJvYXJkRXZlbnQ+KGRvY3VtZW50LCAna2V5ZG93bicpLnN1YnNjcmliZShldmVudCA9PiB0aGlzLm9uS2V5RG93bihldmVudCkpO1xuICAgICAgICB0aGlzLmNsaWNrU3Vic2NyaXB0aW9uID0gZnJvbUV2ZW50PEtleWJvYXJkRXZlbnQ+KGRvY3VtZW50LCAnY2xpY2snKS5zdWJzY3JpYmUoZXZlbnQgPT4gdGhpcy5vbkNsaWNrKGV2ZW50LnRhcmdldCBhcyBIVE1MRWxlbWVudCkpO1xuICAgICAgICB0aGlzLmZpbGxVbmRvUmVkb0FjdGlvbnMoKTtcbiAgICB9XG5cbiAgICBkZXN0cm95KCk6IHZvaWQge1xuICAgICAgICB0aGlzLmltYWdlS2V5RG93blN1YnNjcmlwdGlvbj8udW5zdWJzY3JpYmUoKTtcbiAgICAgICAgdGhpcy5jbGlja1N1YnNjcmlwdGlvbj8udW5zdWJzY3JpYmUoKTtcbiAgICB9XG5cbiAgICBwcml2YXRlIG9uS2V5RG93bihldmVudDogS2V5Ym9hcmRFdmVudCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5lZGl0b3JTZXJ2aWNlLmlzVmlld09ubHkpIHtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChbJ0JhY2tzcGFjZScsICdEZWxldGUnXS5pbmNsdWRlcyhldmVudC5jb2RlKSkge1xuICAgICAgICAgICAgdGhpcy5lZGl0b3JTZXJ2aWNlLnJlbW92ZUltYWdlKHRoaXMuaW1hZ2UuaW5zZXJ0SW5kZXgpO1xuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3Qga2V5Q29tYmluYXRpb24gPSB0aGlzLmdldEtleUNvbWJpbmF0aW9uKGV2ZW50KTtcbiAgICAgICAgaWYgKHRoaXMudW5kb1JlZG9BY3Rpb25zW2tleUNvbWJpbmF0aW9uXSAmJiAhdGhpcy5lZGl0b3JTZXJ2aWNlLmlzVmlld09ubHkpIHtcbiAgICAgICAgICAgIHRoaXMudW5kb1JlZG9BY3Rpb25zW2tleUNvbWJpbmF0aW9uXSgpO1xuICAgICAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmICghZXZlbnQuY3RybEtleSAmJiAhZXZlbnQuYWx0S2V5ICYmICFldmVudC5zaGlmdEtleSAmJiAhZXZlbnQubWV0YUtleSAmJiBldmVudC5rZXkubGVuZ3RoID09PSAxKSB7XG4gICAgICAgICAgICB0aGlzLmVkaXRvclNlcnZpY2UuaW5zZXJ0VGV4dChldmVudC5rZXkpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBnZXRLZXlDb21iaW5hdGlvbihldmVudDogS2V5Ym9hcmRFdmVudCk6IHN0cmluZyB7XG4gICAgICAgIGxldCByZXN1bHQgPSBldmVudC5tZXRhS2V5ID8gJ0NvbW1hbmQtJyA6ICcnO1xuICAgICAgICByZXR1cm4gZXZlbnQuY3RybEtleSA/IGAke3Jlc3VsdH1DdHJsLSR7ZXZlbnQuY29kZX1gIDogJyc7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBmaWxsVW5kb1JlZG9BY3Rpb25zKCk6IHZvaWQge1xuICAgICAgICB0aGlzLnVuZG9SZWRvQWN0aW9uc1snQ3RybC1LZXlaJ10gPSAoKSA9PiB0aGlzLmVkaXRvclNlcnZpY2UudW5kbygpO1xuICAgICAgICB0aGlzLnVuZG9SZWRvQWN0aW9uc1snQ29tbWFuZC1LZXlaJ10gPSAoKSA9PiB0aGlzLmVkaXRvclNlcnZpY2UudW5kbygpO1xuICAgICAgICB0aGlzLnVuZG9SZWRvQWN0aW9uc1snQ3RybC1LZXlZJ10gPSAoKSA9PiB0aGlzLmVkaXRvclNlcnZpY2UucmVkbygpO1xuICAgICAgICB0aGlzLnVuZG9SZWRvQWN0aW9uc1snQ29tbWFuZC1LZXlZJ10gPSAoKSA9PiB0aGlzLmVkaXRvclNlcnZpY2UucmVkbygpO1xuICAgIH1cblxuICAgIHByaXZhdGUgb25DbGljayhlbGVtZW50OiBIVE1MRWxlbWVudCk6IHZvaWQge1xuICAgICAgICBsZXQgY3VycmVudEVsZW1lbnQgPSBlbGVtZW50O1xuICAgICAgICB3aGlsZSAoY3VycmVudEVsZW1lbnQpIHtcbiAgICAgICAgICAgIGlmIChjdXJyZW50RWxlbWVudC50YWdOYW1lID09PSB0aGlzLmltYWdlQ29tcG9uZW50VGFnTmFtZSkge1xuICAgICAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGN1cnJlbnRFbGVtZW50ID0gY3VycmVudEVsZW1lbnQucGFyZW50RWxlbWVudDtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLmVkaXRvclNlcnZpY2UuYmx1ckN1c3RvbUNvbXBvbmVudCgpO1xuICAgIH1cbn1cbiJdfQ==
55
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UtaW5wdXQuaGFuZGxlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1ub2Rlci9zcmMvbGliL2VkaXRvci9jb21wb25lbnRzL2ltYWdlL2lucHV0LWhhbmRsZXIvaW1hZ2UtaW5wdXQuaGFuZGxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFnQixNQUFNLE1BQU0sQ0FBQztBQUsvQyxNQUFNLE9BQU8saUJBQWlCO0lBUzFCLFlBQTZCLGFBQTRCLEVBQW1CLEtBQTBCO1FBQXpFLGtCQUFhLEdBQWIsYUFBYSxDQUFlO1FBQW1CLFVBQUssR0FBTCxLQUFLLENBQXFCO1FBUjdGLDBCQUFxQixHQUFHLGVBQWUsQ0FBQztRQUVoQyxvQkFBZSxHQUFrQyxFQUFFLENBQUM7UUFPakUsSUFBSSxDQUFDLHdCQUF3QixHQUFHLFNBQVMsQ0FBZ0IsUUFBUSxFQUFFLFNBQVMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztRQUN4SCxJQUFJLENBQUMsaUJBQWlCLEdBQUcsU0FBUyxDQUFnQixRQUFRLEVBQUUsT0FBTyxDQUFDLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsTUFBcUIsQ0FBQyxDQUFDLENBQUM7UUFDbkksSUFBSSxDQUFDLG1CQUFtQixFQUFFLENBQUM7SUFDL0IsQ0FBQztJQUVELE9BQU87UUFDSCxJQUFJLENBQUMsd0JBQXdCLEVBQUUsV0FBVyxFQUFFLENBQUM7UUFDN0MsSUFBSSxDQUFDLGlCQUFpQixFQUFFLFdBQVcsRUFBRSxDQUFDO0lBQzFDLENBQUM7SUFFTyxTQUFTLENBQUMsS0FBb0I7UUFDbEMsSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDLFVBQVUsRUFBRTtZQUMvQixPQUFPO1NBQ1Y7UUFFRCxJQUFJLENBQUMsV0FBVyxFQUFFLFFBQVEsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDOUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQztZQUN2RCxPQUFPO1NBQ1Y7UUFFRCxNQUFNLGNBQWMsR0FBRyxJQUFJLENBQUMsaUJBQWlCLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDckQsSUFBSSxJQUFJLENBQUMsZUFBZSxDQUFDLGNBQWMsQ0FBQyxFQUFFO1lBQ3RDLElBQUksQ0FBQyxlQUFlLENBQUMsY0FBYyxDQUFDLEVBQUUsQ0FBQztZQUN2QyxLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7WUFDdkIsT0FBTztTQUNWO1FBRUQsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLElBQUksS0FBSyxDQUFDLEdBQUcsQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1lBQ2hHLElBQUksQ0FBQyxhQUFhLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztTQUM1QztJQUNMLENBQUM7SUFFTyxpQkFBaUIsQ0FBQyxLQUFvQjtRQUMxQyxJQUFJLE1BQU0sR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUM3QyxPQUFPLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEdBQUcsTUFBTSxRQUFRLEtBQUssQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO0lBQzlELENBQUM7SUFFTyxtQkFBbUI7UUFDdkIsSUFBSSxDQUFDLGVBQWUsQ0FBQyxXQUFXLENBQUMsR0FBRyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3BFLElBQUksQ0FBQyxlQUFlLENBQUMsY0FBYyxDQUFDLEdBQUcsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUN2RSxJQUFJLENBQUMsZUFBZSxDQUFDLFdBQVcsQ0FBQyxHQUFHLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDcEUsSUFBSSxDQUFDLGVBQWUsQ0FBQyxjQUFjLENBQUMsR0FBRyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzNFLENBQUM7SUFFTyxPQUFPLENBQUMsT0FBb0I7UUFDaEMsSUFBSSxjQUFjLEdBQUcsT0FBTyxDQUFDO1FBQzdCLE9BQU8sY0FBYyxFQUFFO1lBQ25CLElBQUksY0FBYyxDQUFDLE9BQU8sS0FBSyxJQUFJLENBQUMscUJBQXFCLEVBQUU7Z0JBQ3ZELE9BQU87YUFDVjtZQUNELGNBQWMsR0FBRyxjQUFjLENBQUMsYUFBYSxDQUFDO1NBQ2pEO1FBQ0QsSUFBSSxDQUFDLGFBQWEsQ0FBQyxtQkFBbUIsRUFBRSxDQUFDO0lBQzdDLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGZyb21FdmVudCwgU3Vic2NyaXB0aW9uIH0gZnJvbSAncnhqcyc7XG5cbmltcG9ydCB7IEVkaXRvclNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9pbnRlcmFjdGlvbi9lZGl0b3Iuc2VydmljZSc7XG5pbXBvcnQgeyBOb2RlckltYWdlQ29tcG9uZW50IH0gZnJvbSAnLi4vY29tcG9uZW50cy9pbWFnZS5jb21wb25lbnQnO1xuXG5leHBvcnQgY2xhc3MgSW1hZ2VJbnB1dEhhbmRsZXIge1xuICAgIHJlYWRvbmx5IGltYWdlQ29tcG9uZW50VGFnTmFtZSA9ICdBUFAtTk9ELUlNQUdFJztcblxuICAgIHByaXZhdGUgcmVhZG9ubHkgdW5kb1JlZG9BY3Rpb25zOiB7IFtrZXk6IHN0cmluZ106ICgpID0+IHZvaWQgfSA9IHt9O1xuXG4gICAgcHJpdmF0ZSByZWFkb25seSBpbWFnZUtleURvd25TdWJzY3JpcHRpb246IFN1YnNjcmlwdGlvbjtcblxuICAgIHByaXZhdGUgcmVhZG9ubHkgY2xpY2tTdWJzY3JpcHRpb246IFN1YnNjcmlwdGlvbjtcblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgZWRpdG9yU2VydmljZTogRWRpdG9yU2VydmljZSwgcHJpdmF0ZSByZWFkb25seSBpbWFnZTogTm9kZXJJbWFnZUNvbXBvbmVudCkge1xuICAgICAgICB0aGlzLmltYWdlS2V5RG93blN1YnNjcmlwdGlvbiA9IGZyb21FdmVudDxLZXlib2FyZEV2ZW50Pihkb2N1bWVudCwgJ2tleWRvd24nKS5zdWJzY3JpYmUoZXZlbnQgPT4gdGhpcy5vbktleURvd24oZXZlbnQpKTtcbiAgICAgICAgdGhpcy5jbGlja1N1YnNjcmlwdGlvbiA9IGZyb21FdmVudDxLZXlib2FyZEV2ZW50Pihkb2N1bWVudCwgJ2NsaWNrJykuc3Vic2NyaWJlKGV2ZW50ID0+IHRoaXMub25DbGljayhldmVudC50YXJnZXQgYXMgSFRNTEVsZW1lbnQpKTtcbiAgICAgICAgdGhpcy5maWxsVW5kb1JlZG9BY3Rpb25zKCk7XG4gICAgfVxuXG4gICAgZGVzdHJveSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5pbWFnZUtleURvd25TdWJzY3JpcHRpb24/LnVuc3Vic2NyaWJlKCk7XG4gICAgICAgIHRoaXMuY2xpY2tTdWJzY3JpcHRpb24/LnVuc3Vic2NyaWJlKCk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBvbktleURvd24oZXZlbnQ6IEtleWJvYXJkRXZlbnQpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuZWRpdG9yU2VydmljZS5pc1ZpZXdPbmx5KSB7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICBpZiAoWydCYWNrc3BhY2UnLCAnRGVsZXRlJ10uaW5jbHVkZXMoZXZlbnQuY29kZSkpIHtcbiAgICAgICAgICAgIHRoaXMuZWRpdG9yU2VydmljZS5yZW1vdmVJbWFnZSh0aGlzLmltYWdlLmluc2VydEluZGV4KTtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IGtleUNvbWJpbmF0aW9uID0gdGhpcy5nZXRLZXlDb21iaW5hdGlvbihldmVudCk7XG4gICAgICAgIGlmICh0aGlzLnVuZG9SZWRvQWN0aW9uc1trZXlDb21iaW5hdGlvbl0pIHtcbiAgICAgICAgICAgIHRoaXMudW5kb1JlZG9BY3Rpb25zW2tleUNvbWJpbmF0aW9uXSgpO1xuICAgICAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmICghZXZlbnQuY3RybEtleSAmJiAhZXZlbnQuYWx0S2V5ICYmICFldmVudC5zaGlmdEtleSAmJiAhZXZlbnQubWV0YUtleSAmJiBldmVudC5rZXkubGVuZ3RoID09PSAxKSB7XG4gICAgICAgICAgICB0aGlzLmVkaXRvclNlcnZpY2UuaW5zZXJ0VGV4dChldmVudC5rZXkpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBnZXRLZXlDb21iaW5hdGlvbihldmVudDogS2V5Ym9hcmRFdmVudCk6IHN0cmluZyB7XG4gICAgICAgIGxldCByZXN1bHQgPSBldmVudC5tZXRhS2V5ID8gJ0NvbW1hbmQtJyA6ICcnO1xuICAgICAgICByZXR1cm4gZXZlbnQuY3RybEtleSA/IGAke3Jlc3VsdH1DdHJsLSR7ZXZlbnQuY29kZX1gIDogJyc7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBmaWxsVW5kb1JlZG9BY3Rpb25zKCk6IHZvaWQge1xuICAgICAgICB0aGlzLnVuZG9SZWRvQWN0aW9uc1snQ3RybC1LZXlaJ10gPSAoKSA9PiB0aGlzLmVkaXRvclNlcnZpY2UudW5kbygpO1xuICAgICAgICB0aGlzLnVuZG9SZWRvQWN0aW9uc1snQ29tbWFuZC1LZXlaJ10gPSAoKSA9PiB0aGlzLmVkaXRvclNlcnZpY2UudW5kbygpO1xuICAgICAgICB0aGlzLnVuZG9SZWRvQWN0aW9uc1snQ3RybC1LZXlZJ10gPSAoKSA9PiB0aGlzLmVkaXRvclNlcnZpY2UucmVkbygpO1xuICAgICAgICB0aGlzLnVuZG9SZWRvQWN0aW9uc1snQ29tbWFuZC1LZXlZJ10gPSAoKSA9PiB0aGlzLmVkaXRvclNlcnZpY2UucmVkbygpO1xuICAgIH1cblxuICAgIHByaXZhdGUgb25DbGljayhlbGVtZW50OiBIVE1MRWxlbWVudCk6IHZvaWQge1xuICAgICAgICBsZXQgY3VycmVudEVsZW1lbnQgPSBlbGVtZW50O1xuICAgICAgICB3aGlsZSAoY3VycmVudEVsZW1lbnQpIHtcbiAgICAgICAgICAgIGlmIChjdXJyZW50RWxlbWVudC50YWdOYW1lID09PSB0aGlzLmltYWdlQ29tcG9uZW50VGFnTmFtZSkge1xuICAgICAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGN1cnJlbnRFbGVtZW50ID0gY3VycmVudEVsZW1lbnQucGFyZW50RWxlbWVudDtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLmVkaXRvclNlcnZpY2UuYmx1ckN1c3RvbUNvbXBvbmVudCgpO1xuICAgIH1cbn1cbiJdfQ==
@@ -23,8 +23,7 @@ export class NoderTableCellComponent {
23
23
  return;
24
24
  }
25
25
  this._allParagraphsHeight = event.pageHeight;
26
- const cellContentHeight = this._allParagraphsHeight;
27
- this.heightChanged(this.rowIndex, this.cellIndex, cellContentHeight);
26
+ this.heightChanged(this.rowIndex, this.cellIndex, event.pageHeight);
28
27
  };
29
28
  }
30
29
  ngOnDestroy() {
@@ -52,6 +51,9 @@ export class NoderTableCellComponent {
52
51
  this.editorService.disableSelection();
53
52
  }
54
53
  onStartResizing(event, border) {
54
+ if (this.session.isWithinEdge() && !this.regulatorService.mainSession.session.customComponents.edges.isEdit) {
55
+ return;
56
+ }
55
57
  event.stopPropagation();
56
58
  this.startResizing(new CellResizerParametersModel(this.columnIndex, this.rowIndex, this.cellIndex, border));
57
59
  }
@@ -94,4 +96,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
94
96
  type: ViewChild,
95
97
  args: ['container', { static: true }]
96
98
  }] } });
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"]}
99
+ //# 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        if (this.session.isWithinEdge() && !this.regulatorService.mainSession.session.customComponents.edges.isEdit) {\n            return;\n        }\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        this.heightChanged(this.rowIndex, this.cellIndex, event.pageHeight);\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"]}