@talrace/ngx-noder 0.0.17 → 0.0.18
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +72 -9
- package/assets/i18n/noder.en.json +93 -0
- package/assets/i18n/noder.es.json +93 -0
- package/assets/i18n/noder.ru.json +93 -0
- package/esm2022/lib/apart-components/add-link-dialog/add-link-dialog.component.mjs +21 -21
- package/esm2022/lib/apart-components/add-link-mobile/add-link-mobile.component.mjs +5 -3
- package/esm2022/lib/apart-components/confirm-dialog/confirm-dialog.component.mjs +5 -3
- package/esm2022/lib/apart-components/editor-search/editor-search-dialog.component.mjs +14 -3
- package/esm2022/lib/apart-components/editor-title/editor-title.component.mjs +17 -14
- package/esm2022/lib/apart-components/editor-title-mobile/editor-title-mobile.component.mjs +5 -3
- package/esm2022/lib/apart-components/editor-toolbar/components/buttons/color-picker/color-picker.component.mjs +3 -3
- package/esm2022/lib/apart-components/editor-toolbar/components/buttons/font/font.component.mjs +3 -3
- package/esm2022/lib/apart-components/editor-toolbar/components/buttons/format/format.component.mjs +3 -3
- package/esm2022/lib/apart-components/editor-toolbar/components/buttons/numbering/numbering.component.mjs +3 -3
- package/esm2022/lib/apart-components/editor-toolbar/components/menu-dropdowns/menu-dropdowns.component.mjs +4 -3
- package/esm2022/lib/apart-components/editor-toolbar/components/menu-dropdowns-mobile/menu-dropdowns-mobile.component.mjs +4 -3
- package/esm2022/lib/apart-components/editor-toolbar/components/toolbar-actions/toolbar-actions.component.mjs +2 -2
- package/esm2022/lib/apart-components/editor-toolbar/editor-mobile-toolbar/editor-mobile-toolbar.component.mjs +18 -16
- package/esm2022/lib/apart-components/editor-toolbar/editor-toolbar.module.mjs +8 -13
- package/esm2022/lib/apart-components/insert-table-mobile/insert-table-mobile.component.mjs +5 -3
- package/esm2022/lib/apart-components/text-format-mobile/text-format-mobile.component.mjs +14 -3
- package/esm2022/lib/editor/components/edges/edge.component.mjs +48 -6
- package/esm2022/lib/editor/components/edges/edges.mjs +7 -29
- package/esm2022/lib/editor/components/external-element/models/external-element.model.mjs +4 -4
- package/esm2022/lib/editor/components/table/overlay-menu/overlay-menu.component.mjs +29 -19
- package/esm2022/lib/editor/editor.module.mjs +28 -4
- package/esm2022/lib/editor/execution/editor.mjs +2 -1
- package/esm2022/lib/editor/gadgets/scrollbar.mjs +11 -6
- package/esm2022/lib/translate/noder-translate.loader.mjs +22 -0
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/talrace-ngx-noder.mjs +241 -168
- package/fesm2022/talrace-ngx-noder.mjs.map +1 -1
- package/lib/apart-components/add-link-dialog/add-link-dialog.component.d.ts +1 -10
- package/lib/apart-components/editor-title/editor-title.component.d.ts +5 -3
- package/lib/apart-components/editor-toolbar/editor-mobile-toolbar/editor-mobile-toolbar.component.d.ts +3 -1
- package/lib/apart-components/editor-toolbar/editor-toolbar.module.d.ts +23 -23
- package/lib/editor/components/edges/edge.component.d.ts +10 -3
- package/lib/editor/components/edges/edges.d.ts +0 -2
- package/lib/editor/components/external-element/models/external-element.model.d.ts +3 -3
- package/lib/editor/components/table/overlay-menu/overlay-menu.component.d.ts +3 -1
- package/lib/editor/editor.module.d.ts +2 -1
- package/lib/editor/gadgets/scrollbar.d.ts +1 -0
- package/lib/translate/noder-translate.loader.d.ts +11 -0
- package/package.json +3 -1
- package/public-api.d.ts +1 -0
- package/esm2022/lib/apart-components/editor-toolbar/components/buttons/heading/heading.component.mjs +0 -22
- package/lib/apart-components/editor-toolbar/components/buttons/heading/heading.component.d.ts +0 -8
|
@@ -1,10 +1,13 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, Input, ViewChild } from '@angular/core';
|
|
2
|
+
import { startWith, takeUntil } from 'rxjs';
|
|
2
3
|
import { DestroyComponent } from '../shared/abstract/destroy.component';
|
|
3
4
|
import { DomHelper } from '../../execution/helpers/dom.helper';
|
|
4
5
|
import { EdgeType } from './edge-type.enum';
|
|
6
|
+
import { PageType } from './page-type.enum';
|
|
5
7
|
import * as i0 from "@angular/core";
|
|
6
8
|
import * as i1 from "../../execution/regulator.service";
|
|
7
9
|
import * as i2 from "../../interaction/editor.service";
|
|
10
|
+
import * as i3 from "@ngx-translate/core";
|
|
8
11
|
export class NoderEdgeComponent extends DestroyComponent {
|
|
9
12
|
set type(val) {
|
|
10
13
|
this._type = val;
|
|
@@ -29,10 +32,13 @@ export class NoderEdgeComponent extends DestroyComponent {
|
|
|
29
32
|
get contentHeight() {
|
|
30
33
|
return this.session.displayData.defaultVerticalData.contentHeight;
|
|
31
34
|
}
|
|
32
|
-
constructor(regulatorService, editorService) {
|
|
35
|
+
constructor(regulatorService, editorService, cdr, translateService) {
|
|
33
36
|
super();
|
|
34
37
|
this.regulatorService = regulatorService;
|
|
35
38
|
this.editorService = editorService;
|
|
39
|
+
this.cdr = cdr;
|
|
40
|
+
this.translateService = translateService;
|
|
41
|
+
this.initialized = false;
|
|
36
42
|
this.pagesCountChangedHandler = (event) => {
|
|
37
43
|
if (this._height === event.pageHeight) {
|
|
38
44
|
return;
|
|
@@ -55,6 +61,14 @@ export class NoderEdgeComponent extends DestroyComponent {
|
|
|
55
61
|
DomHelper.setStyle(this.typeContainer.nativeElement.style, 'visibility', 'hidden');
|
|
56
62
|
this.applyHeight();
|
|
57
63
|
this.session.displayData.addEventListener('pagesCountChanged', this.pagesCountChangedHandler);
|
|
64
|
+
if (this.initialized) {
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
this.initialized = true;
|
|
68
|
+
this.translateService.onLangChange.pipe(startWith(null), takeUntil(this.destroy$)).subscribe(() => {
|
|
69
|
+
this.edgeNameByType = this.getEdgeNameByType();
|
|
70
|
+
this.cdr.detectChanges();
|
|
71
|
+
});
|
|
58
72
|
}
|
|
59
73
|
enterEditMode() {
|
|
60
74
|
DomHelper.addCssClass(this.container.nativeElement, this.editModeClass);
|
|
@@ -66,18 +80,44 @@ export class NoderEdgeComponent extends DestroyComponent {
|
|
|
66
80
|
DomHelper.setStyle(this.typeContainer.nativeElement.style, 'visibility', 'hidden');
|
|
67
81
|
this.editorService.changedEdge(this.sessionId);
|
|
68
82
|
}
|
|
83
|
+
getEdgeNameByType() {
|
|
84
|
+
if (this.type === EdgeType.Header) {
|
|
85
|
+
if (this.model.pageType === PageType.First) {
|
|
86
|
+
return this.translateService.instant('NODER.LABEL.FIRST_PAGE_HEADER');
|
|
87
|
+
}
|
|
88
|
+
else if (this.model.pageType === PageType.Even) {
|
|
89
|
+
return this.translateService.instant('NODER.LABEL.EVEN_PAGES_HEADER');
|
|
90
|
+
}
|
|
91
|
+
else if (this.model.pageType === PageType.Default && this.isEvenEdgesExist) {
|
|
92
|
+
return this.translateService.instant('NODER.LABEL.ODD_PAGES_HEADER');
|
|
93
|
+
}
|
|
94
|
+
return this.translateService.instant('NODER.LABEL.HEADER');
|
|
95
|
+
}
|
|
96
|
+
else {
|
|
97
|
+
if (this.model.pageType === PageType.First) {
|
|
98
|
+
return this.translateService.instant('NODER.LABEL.FIRST_PAGE_FOOTER');
|
|
99
|
+
}
|
|
100
|
+
else if (this.model.pageType === PageType.Even) {
|
|
101
|
+
return this.translateService.instant('NODER.LABEL.EVEN_PAGES_FOOTER');
|
|
102
|
+
}
|
|
103
|
+
else if (this.model.pageType === PageType.Default && this.isEvenEdgesExist) {
|
|
104
|
+
return this.translateService.instant('NODER.LABEL.ODD_PAGES_FOOTER');
|
|
105
|
+
}
|
|
106
|
+
return this.translateService.instant('NODER.LABEL.FOOTER');
|
|
107
|
+
}
|
|
108
|
+
}
|
|
69
109
|
applyHeight() {
|
|
70
110
|
const maxHeight = this.generalProperties.maxEdgeHeight;
|
|
71
111
|
const height = this.contentHeight > maxHeight ? maxHeight : this.contentHeight;
|
|
72
112
|
DomHelper.setStyle(this.typeContainer.nativeElement.style, this.typeContainerPosition, `${height}px`);
|
|
73
113
|
}
|
|
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 }); }
|
|
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\"
|
|
114
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NoderEdgeComponent, deps: [{ token: i1.RegulatorService }, { token: i2.EditorService }, { token: i0.ChangeDetectorRef }, { token: i3.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
115
|
+
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", isEvenEdgesExist: "isEvenEdgesExist", 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\">\n <span>{{ edgeNameByType }}</span>\n</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 }); }
|
|
76
116
|
}
|
|
77
117
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NoderEdgeComponent, decorators: [{
|
|
78
118
|
type: Component,
|
|
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\"
|
|
80
|
-
}], ctorParameters: () => [{ type: i1.RegulatorService }, { type: i2.EditorService }], propDecorators: { model: [{
|
|
119
|
+
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\">\n <span>{{ edgeNameByType }}</span>\n</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"] }]
|
|
120
|
+
}], ctorParameters: () => [{ type: i1.RegulatorService }, { type: i2.EditorService }, { type: i0.ChangeDetectorRef }, { type: i3.TranslateService }], propDecorators: { model: [{
|
|
81
121
|
type: Input
|
|
82
122
|
}], generalProperties: [{
|
|
83
123
|
type: Input
|
|
@@ -87,6 +127,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
87
127
|
type: Input
|
|
88
128
|
}], parentSessionId: [{
|
|
89
129
|
type: Input
|
|
130
|
+
}], isEvenEdgesExist: [{
|
|
131
|
+
type: Input
|
|
90
132
|
}], type: [{
|
|
91
133
|
type: Input
|
|
92
134
|
}], container: [{
|
|
@@ -96,4 +138,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
96
138
|
type: ViewChild,
|
|
97
139
|
args: ['locationType', { static: true }]
|
|
98
140
|
}] } });
|
|
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"]}
|
|
141
|
+
//# 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, ChangeDetectorRef, Component, ElementRef, Input, ViewChild } from '@angular/core';\nimport { startWith, takeUntil } from 'rxjs';\nimport { TranslateService } from '@ngx-translate/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() isEvenEdgesExist: boolean;\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    edgeNameByType: string;\n\n    initialized = false;\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(\n        private regulatorService: RegulatorService,\n        private editorService: EditorService,\n        private cdr: ChangeDetectorRef,\n        private translateService: TranslateService\n    ) {\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        if (this.initialized) {\n            return;\n        }\n        this.initialized = true;\n        this.translateService.onLangChange.pipe(startWith(null), takeUntil(this.destroy$)).subscribe(() => {\n            this.edgeNameByType = this.getEdgeNameByType();\n            this.cdr.detectChanges();\n        });\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 getEdgeNameByType(): string {\n        if (this.type === EdgeType.Header) {\n            if (this.model.pageType === PageType.First) {\n                return this.translateService.instant('NODER.LABEL.FIRST_PAGE_HEADER');\n            } else if (this.model.pageType === PageType.Even) {\n                return this.translateService.instant('NODER.LABEL.EVEN_PAGES_HEADER');\n            } else if (this.model.pageType === PageType.Default && this.isEvenEdgesExist) {\n                return this.translateService.instant('NODER.LABEL.ODD_PAGES_HEADER');\n            }\n            return this.translateService.instant('NODER.LABEL.HEADER');\n        } else {\n            if (this.model.pageType === PageType.First) {\n                return this.translateService.instant('NODER.LABEL.FIRST_PAGE_FOOTER');\n            } else if (this.model.pageType === PageType.Even) {\n                return this.translateService.instant('NODER.LABEL.EVEN_PAGES_FOOTER');\n            } else if (this.model.pageType === PageType.Default && this.isEvenEdgesExist) {\n                return this.translateService.instant('NODER.LABEL.ODD_PAGES_FOOTER');\n            }\n            return this.translateService.instant('NODER.LABEL.FOOTER');\n        }\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\">\n    <span>{{ edgeNameByType }}</span>\n</div>\n"]}
|
|
@@ -10,15 +10,15 @@ export class Edges {
|
|
|
10
10
|
this.headersComponents = [];
|
|
11
11
|
this.footersComponents = [];
|
|
12
12
|
this.isEdit = false;
|
|
13
|
+
const isEvenEdgesExist = headers?.some(x => x.pageType === PageType.Even) || footers?.some(x => x.pageType === PageType.Even);
|
|
13
14
|
if (headers) {
|
|
14
15
|
const headerMargins = new MarginModel({ ...margins, bottom: 0 });
|
|
15
|
-
this.headersComponents = this.createComponents(headers, pageWidth, headerMargins, EdgeType.Header);
|
|
16
|
+
this.headersComponents = this.createComponents(headers, pageWidth, headerMargins, EdgeType.Header, isEvenEdgesExist);
|
|
16
17
|
}
|
|
17
18
|
if (footers) {
|
|
18
19
|
const footerMargins = new MarginModel({ ...margins, top: 0 });
|
|
19
|
-
this.footersComponents = this.createComponents(footers, pageWidth, footerMargins, EdgeType.Footer);
|
|
20
|
+
this.footersComponents = this.createComponents(footers, pageWidth, footerMargins, EdgeType.Footer, isEvenEdgesExist);
|
|
20
21
|
}
|
|
21
|
-
this.setEdgeNameToComponents();
|
|
22
22
|
}
|
|
23
23
|
getTypeBySessionId(sessionId) {
|
|
24
24
|
let component = this.headersComponents.find(x => x.instance.sessionId === sessionId);
|
|
@@ -73,7 +73,7 @@ export class Edges {
|
|
|
73
73
|
const edgeComponents = [...this.headersComponents, ...this.footersComponents];
|
|
74
74
|
return [...new Set(edgeComponents.map(x => x.instance.model.pageType))];
|
|
75
75
|
}
|
|
76
|
-
createComponents(edgeModels, pageWidth, margins, type) {
|
|
76
|
+
createComponents(edgeModels, pageWidth, margins, type, isEvenEdgesExist) {
|
|
77
77
|
const resultComponents = [];
|
|
78
78
|
const hasFirstEdge = edgeModels.some(edge => edge.pageType === PageType.First);
|
|
79
79
|
for (let model of edgeModels.sort((x, y) => {
|
|
@@ -101,7 +101,8 @@ export class Edges {
|
|
|
101
101
|
type,
|
|
102
102
|
width: pageWidth,
|
|
103
103
|
generalProperties: this.generalProperties,
|
|
104
|
-
parentSessionId: this.parentSessionId
|
|
104
|
+
parentSessionId: this.parentSessionId,
|
|
105
|
+
isEvenEdgesExist
|
|
105
106
|
});
|
|
106
107
|
resultComponents.push(componentRef);
|
|
107
108
|
}
|
|
@@ -115,28 +116,5 @@ export class Edges {
|
|
|
115
116
|
const targetType = page % 2 === 0 ? PageType.Even : PageType.Default;
|
|
116
117
|
return edgeComponents.find(x => x.instance.model.pageType === targetType) || defaultComponent;
|
|
117
118
|
}
|
|
118
|
-
setEdgeNameToComponents() {
|
|
119
|
-
const edgeComponents = [...this.headersComponents, ...this.footersComponents];
|
|
120
|
-
if (!edgeComponents.length) {
|
|
121
|
-
return;
|
|
122
|
-
}
|
|
123
|
-
const isEvenEdgesExist = edgeComponents.some(x => x.instance.model.pageType === PageType.Even);
|
|
124
|
-
for (let component of edgeComponents) {
|
|
125
|
-
component.instance.typeContainer.nativeElement.innerText = this.getEdgeNameByType(component.instance, isEvenEdgesExist);
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
getEdgeNameByType(component, isEvenEdgesExist) {
|
|
129
|
-
let edgeName = component.type === EdgeType.Header ? 'Header' : 'Footer';
|
|
130
|
-
if (component.model.pageType === PageType.First) {
|
|
131
|
-
edgeName = `First Page ${edgeName}`;
|
|
132
|
-
}
|
|
133
|
-
else if (component.model.pageType === PageType.Even) {
|
|
134
|
-
edgeName = `Even Pages ${edgeName}`;
|
|
135
|
-
}
|
|
136
|
-
else if (component.model.pageType === PageType.Default && isEvenEdgesExist) {
|
|
137
|
-
edgeName = `Odd Pages ${edgeName}`;
|
|
138
|
-
}
|
|
139
|
-
return edgeName;
|
|
140
|
-
}
|
|
141
119
|
}
|
|
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"]}
|
|
120
|
+
//# 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        const isEvenEdgesExist = headers?.some(x => x.pageType === PageType.Even) || footers?.some(x => x.pageType === PageType.Even);\n        if (headers) {\n            const headerMargins = new MarginModel({ ...margins, bottom: 0 });\n            this.headersComponents = this.createComponents(headers, pageWidth, headerMargins, EdgeType.Header, isEvenEdgesExist);\n        }\n\n        if (footers) {\n            const footerMargins = new MarginModel({ ...margins, top: 0 });\n            this.footersComponents = this.createComponents(footers, pageWidth, footerMargins, EdgeType.Footer, isEvenEdgesExist);\n        }\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        isEvenEdgesExist: boolean\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                isEvenEdgesExist\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"]}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
export class ExternalElementModel {
|
|
2
|
-
constructor(
|
|
3
|
-
this.
|
|
4
|
-
this.
|
|
2
|
+
constructor(nameTranslate = 'NODER.LABEL.NONE', nameId = 'none', icon, type, componentType, factoryMethod) {
|
|
3
|
+
this.nameTranslate = nameTranslate;
|
|
4
|
+
this.nameId = nameId;
|
|
5
5
|
this.icon = icon;
|
|
6
6
|
this.type = type;
|
|
7
7
|
this.componentType = componentType;
|
|
8
8
|
this.factoryMethod = factoryMethod;
|
|
9
9
|
}
|
|
10
10
|
}
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXh0ZXJuYWwtZWxlbWVudC5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1ub2Rlci9zcmMvbGliL2VkaXRvci9jb21wb25lbnRzL2V4dGVybmFsLWVsZW1lbnQvbW9kZWxzL2V4dGVybmFsLWVsZW1lbnQubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBSUEsTUFBTSxPQUFPLG9CQUFvQjtJQUM3QixZQUNXLGdCQUF3QixrQkFBa0IsRUFDMUMsU0FBaUIsTUFBTSxFQUN2QixJQUFZLEVBQ1osSUFBWSxFQUNaLGFBQXVDLEVBQ3ZDLGFBQTJGO1FBTDNGLGtCQUFhLEdBQWIsYUFBYSxDQUE2QjtRQUMxQyxXQUFNLEdBQU4sTUFBTSxDQUFpQjtRQUN2QixTQUFJLEdBQUosSUFBSSxDQUFRO1FBQ1osU0FBSSxHQUFKLElBQUksQ0FBUTtRQUNaLGtCQUFhLEdBQWIsYUFBYSxDQUEwQjtRQUN2QyxrQkFBYSxHQUFiLGFBQWEsQ0FBOEU7SUFDbkcsQ0FBQztDQUNQIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBCYXNlTm9kZXJDb21wb25lbnQgfSBmcm9tICcuLi8uLi9zaGFyZWQvYWJzdHJhY3QvYmFzZS5jb21wb25lbnQnO1xuXG5leHBvcnQgY2xhc3MgRXh0ZXJuYWxFbGVtZW50TW9kZWwge1xuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwdWJsaWMgbmFtZVRyYW5zbGF0ZTogc3RyaW5nID0gJ05PREVSLkxBQkVMLk5PTkUnLFxuICAgICAgICBwdWJsaWMgbmFtZUlkOiBzdHJpbmcgPSAnbm9uZScsXG4gICAgICAgIHB1YmxpYyBpY29uOiBzdHJpbmcsXG4gICAgICAgIHB1YmxpYyB0eXBlOiBudW1iZXIsXG4gICAgICAgIHB1YmxpYyBjb21wb25lbnRUeXBlOiBUeXBlPEJhc2VOb2RlckNvbXBvbmVudD4sXG4gICAgICAgIHB1YmxpYyBmYWN0b3J5TWV0aG9kOiAoKSA9PiBQcm9taXNlPHsgZ3VpZDogc3RyaW5nOyB0eXBlOiBudW1iZXI7IHdpZHRoOiBudW1iZXI7IGhlaWdodDogbnVtYmVyIH0+XG4gICAgKSB7fVxufVxuIl19
|
|
@@ -2,12 +2,14 @@ import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
import * as i1 from "../../../interaction/editor.service";
|
|
4
4
|
import * as i2 from "../../shared/services/overlay.service";
|
|
5
|
-
import * as i3 from "@
|
|
6
|
-
import * as i4 from "@angular/
|
|
5
|
+
import * as i3 from "@ngx-translate/core";
|
|
6
|
+
import * as i4 from "@angular/common";
|
|
7
|
+
import * as i5 from "@angular/material/icon";
|
|
7
8
|
export class TableOverlayMenuComponent {
|
|
8
|
-
constructor(editorService, overlayService) {
|
|
9
|
+
constructor(editorService, overlayService, translateService) {
|
|
9
10
|
this.editorService = editorService;
|
|
10
11
|
this.overlayService = overlayService;
|
|
12
|
+
this.translateService = translateService;
|
|
11
13
|
}
|
|
12
14
|
ngOnInit() {
|
|
13
15
|
this.selectedRowsCount = this.selectionRange.rowIndexes.endIndex - this.selectionRange.rowIndexes.startIndex + 1;
|
|
@@ -15,18 +17,26 @@ export class TableOverlayMenuComponent {
|
|
|
15
17
|
this.processInsertMenuItems();
|
|
16
18
|
}
|
|
17
19
|
processInsertMenuItems() {
|
|
18
|
-
const
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
20
|
+
const insertRowsAboveMessage = this.selectedRowsCount > 1
|
|
21
|
+
? this.translateService.instant('NODER.COMPLEX_LABEL.INSERT_ROWS_ABOVE', { count: this.selectedRowsCount })
|
|
22
|
+
: this.translateService.instant('NODER.LABEL.INSERT_ROW_ABOVE');
|
|
23
|
+
const insertRowsBelowMessage = this.selectedRowsCount > 1
|
|
24
|
+
? this.translateService.instant('NODER.COMPLEX_LABEL.INSERT_ROWS_BELOW', { count: this.selectedRowsCount })
|
|
25
|
+
: this.translateService.instant('NODER.LABEL.INSERT_ROW_BELOW');
|
|
26
|
+
const insertColumnsLeftMessage = this.selectedRowsCount > 1
|
|
27
|
+
? this.translateService.instant('NODER.COMPLEX_LABEL.INSERT_COLUMNS_TO_THE_LEFT', { count: this.selectedColumnsCount })
|
|
28
|
+
: this.translateService.instant('NODER.LABEL.INSERT_COLUMN_TO_THE_LEFT');
|
|
29
|
+
const insertColumnsRightMessage = this.selectedRowsCount > 1
|
|
30
|
+
? this.translateService.instant('NODER.COMPLEX_LABEL.INSERT_COLUMNS_TO_THE_RIGHT', { count: this.selectedColumnsCount })
|
|
31
|
+
: this.translateService.instant('NODER.LABEL.INSERT_COLUMN_TO_THE_RIGHT');
|
|
32
|
+
const removeRowsMessage = this.selectedRowsCount > 1
|
|
33
|
+
? this.translateService.instant('NODER.COMPLEX_LABEL.REMOVE_ROWS', { count: this.selectedRowsCount })
|
|
34
|
+
: this.translateService.instant('NODER.LABEL.REMOVE_ROW');
|
|
35
|
+
const removeColumnsMessage = this.selectedRowsCount > 1
|
|
36
|
+
? this.translateService.instant('NODER.COMPLEX_LABEL.REMOVE_COLUMNS', { count: this.selectedColumnsCount })
|
|
37
|
+
: this.translateService.instant('NODER.LABEL.REMOVE_COLUMN');
|
|
38
|
+
this.insertMessages = { insertRowsAboveMessage, insertRowsBelowMessage, insertColumnsLeftMessage, insertColumnsRightMessage };
|
|
39
|
+
this.removeMessages = { removeRowsMessage, removeColumnsMessage };
|
|
30
40
|
}
|
|
31
41
|
onInsertRowsAbove() {
|
|
32
42
|
this.editorService.insertTableRows(this.tableInsertIndex, this.selectedRowsCount, this.targets.rowIndexes.startIndex, this.selectionRange.rowIndexes.startIndex, this.sessionId);
|
|
@@ -52,13 +62,13 @@ export class TableOverlayMenuComponent {
|
|
|
52
62
|
this.editorService.removeTableColumns(this.tableInsertIndex, this.selectionRange.cellIndexes.startIndex, this.selectionRange.cellIndexes.endIndex, this.sessionId);
|
|
53
63
|
this.overlayService.close();
|
|
54
64
|
}
|
|
55
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TableOverlayMenuComponent, deps: [{ token: i1.EditorService }, { token: i2.OverlayService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
56
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TableOverlayMenuComponent, selector: "app-nod-table-overlay-menu", inputs: { selectionRange: "selectionRange", targets: "targets", canRemoveRows: "canRemoveRows", canRemoveColumns: "canRemoveColumns", tableInsertIndex: "tableInsertIndex", sessionId: "sessionId" }, ngImport: i0, template: "<div\n class=\"menu-item\"\n (click)=\"onInsertRowsAbove()\">\n <mat-icon\n fontSet=\"noder-icon\"\n fontIcon=\"icon-add\"></mat-icon>\n {{ insertMessages.insertRowsAboveMessage }}\n</div>\n<div\n class=\"menu-item\"\n (click)=\"onInsertRowsBelow()\">\n <mat-icon\n fontSet=\"noder-icon\"\n fontIcon=\"icon-add\"></mat-icon>\n {{ insertMessages.insertRowsBelowMessage }}\n</div>\n<div\n class=\"menu-item\"\n (click)=\"onInsertColumnsLeft()\">\n <mat-icon\n fontSet=\"noder-icon\"\n fontIcon=\"icon-add\"></mat-icon>\n {{ insertMessages.insertColumnsLeftMessage }}\n</div>\n<div\n class=\"menu-item\"\n (click)=\"onInsertColumnsRight()\">\n <mat-icon\n fontSet=\"noder-icon\"\n fontIcon=\"icon-add\"></mat-icon>\n {{ insertMessages.insertColumnsRightMessage }}\n</div>\n<ng-container *ngIf=\"canRemoveRows || canRemoveColumns\">\n <div class=\"menu-separator\">\n <div class=\"menu-separator-top\"></div>\n <div class=\"menu-separator-bottom\"></div>\n </div>\n <div\n *ngIf=\"canRemoveRows\"\n class=\"menu-item\"\n (click)=\"onRemoveRows()\">\n <mat-icon\n fontSet=\"noder-icon\"\n fontIcon=\"icon-delete\"></mat-icon>\n {{ removeMessages.removeRowsMessage }}\n </div>\n <div\n *ngIf=\"canRemoveColumns\"\n class=\"menu-item\"\n (click)=\"onRemoveColumns()\">\n <mat-icon\n fontSet=\"noder-icon\"\n fontIcon=\"icon-delete\"></mat-icon>\n {{ removeMessages.removeColumnsMessage }}\n </div>\n</ng-container>\n", styles: [":host{position:absolute;border:1px solid transparent;border-radius:4px;box-shadow:0 2px 6px 2px #3c404326;overflow-y:auto;background:#fff;cursor:default;font-size:13px;margin:0;padding:6px 0}.menu-item{display:flex;flex-direction:row;align-items:center;cursor:pointer;min-height:20px;color:#202124;font-size:16px;letter-spacing:.2px;line-height:20px;padding:6px}.menu-item:hover{background-color:#0000001a}.mat-icon{margin-right:6px;width:20px;height:20px;font-size:20px}.menu-separator{-webkit-user-select:none;user-select:none}.menu-separator .menu-separator-top{padding:4px}.menu-separator .menu-separator-bottom{border-top:1px solid #dadce0;padding:4px}\n"], dependencies: [{ kind: "directive", type:
|
|
65
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TableOverlayMenuComponent, deps: [{ token: i1.EditorService }, { token: i2.OverlayService }, { token: i3.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
66
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TableOverlayMenuComponent, selector: "app-nod-table-overlay-menu", inputs: { selectionRange: "selectionRange", targets: "targets", canRemoveRows: "canRemoveRows", canRemoveColumns: "canRemoveColumns", tableInsertIndex: "tableInsertIndex", sessionId: "sessionId" }, ngImport: i0, template: "<div\n class=\"menu-item\"\n (click)=\"onInsertRowsAbove()\">\n <mat-icon\n fontSet=\"noder-icon\"\n fontIcon=\"icon-add\"></mat-icon>\n {{ insertMessages.insertRowsAboveMessage }}\n</div>\n<div\n class=\"menu-item\"\n (click)=\"onInsertRowsBelow()\">\n <mat-icon\n fontSet=\"noder-icon\"\n fontIcon=\"icon-add\"></mat-icon>\n {{ insertMessages.insertRowsBelowMessage }}\n</div>\n<div\n class=\"menu-item\"\n (click)=\"onInsertColumnsLeft()\">\n <mat-icon\n fontSet=\"noder-icon\"\n fontIcon=\"icon-add\"></mat-icon>\n {{ insertMessages.insertColumnsLeftMessage }}\n</div>\n<div\n class=\"menu-item\"\n (click)=\"onInsertColumnsRight()\">\n <mat-icon\n fontSet=\"noder-icon\"\n fontIcon=\"icon-add\"></mat-icon>\n {{ insertMessages.insertColumnsRightMessage }}\n</div>\n<ng-container *ngIf=\"canRemoveRows || canRemoveColumns\">\n <div class=\"menu-separator\">\n <div class=\"menu-separator-top\"></div>\n <div class=\"menu-separator-bottom\"></div>\n </div>\n <div\n *ngIf=\"canRemoveRows\"\n class=\"menu-item\"\n (click)=\"onRemoveRows()\">\n <mat-icon\n fontSet=\"noder-icon\"\n fontIcon=\"icon-delete\"></mat-icon>\n {{ removeMessages.removeRowsMessage }}\n </div>\n <div\n *ngIf=\"canRemoveColumns\"\n class=\"menu-item\"\n (click)=\"onRemoveColumns()\">\n <mat-icon\n fontSet=\"noder-icon\"\n fontIcon=\"icon-delete\"></mat-icon>\n {{ removeMessages.removeColumnsMessage }}\n </div>\n</ng-container>\n", styles: [":host{position:absolute;border:1px solid transparent;border-radius:4px;box-shadow:0 2px 6px 2px #3c404326;overflow-y:auto;background:#fff;cursor:default;font-size:13px;margin:0;padding:6px 0}.menu-item{display:flex;flex-direction:row;align-items:center;cursor:pointer;min-height:20px;color:#202124;font-size:16px;letter-spacing:.2px;line-height:20px;padding:6px}.menu-item:hover{background-color:#0000001a}.mat-icon{margin-right:6px;width:20px;height:20px;font-size:20px}.menu-separator{-webkit-user-select:none;user-select:none}.menu-separator .menu-separator-top{padding:4px}.menu-separator .menu-separator-bottom{border-top:1px solid #dadce0;padding:4px}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
57
67
|
}
|
|
58
68
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TableOverlayMenuComponent, decorators: [{
|
|
59
69
|
type: Component,
|
|
60
70
|
args: [{ selector: 'app-nod-table-overlay-menu', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"menu-item\"\n (click)=\"onInsertRowsAbove()\">\n <mat-icon\n fontSet=\"noder-icon\"\n fontIcon=\"icon-add\"></mat-icon>\n {{ insertMessages.insertRowsAboveMessage }}\n</div>\n<div\n class=\"menu-item\"\n (click)=\"onInsertRowsBelow()\">\n <mat-icon\n fontSet=\"noder-icon\"\n fontIcon=\"icon-add\"></mat-icon>\n {{ insertMessages.insertRowsBelowMessage }}\n</div>\n<div\n class=\"menu-item\"\n (click)=\"onInsertColumnsLeft()\">\n <mat-icon\n fontSet=\"noder-icon\"\n fontIcon=\"icon-add\"></mat-icon>\n {{ insertMessages.insertColumnsLeftMessage }}\n</div>\n<div\n class=\"menu-item\"\n (click)=\"onInsertColumnsRight()\">\n <mat-icon\n fontSet=\"noder-icon\"\n fontIcon=\"icon-add\"></mat-icon>\n {{ insertMessages.insertColumnsRightMessage }}\n</div>\n<ng-container *ngIf=\"canRemoveRows || canRemoveColumns\">\n <div class=\"menu-separator\">\n <div class=\"menu-separator-top\"></div>\n <div class=\"menu-separator-bottom\"></div>\n </div>\n <div\n *ngIf=\"canRemoveRows\"\n class=\"menu-item\"\n (click)=\"onRemoveRows()\">\n <mat-icon\n fontSet=\"noder-icon\"\n fontIcon=\"icon-delete\"></mat-icon>\n {{ removeMessages.removeRowsMessage }}\n </div>\n <div\n *ngIf=\"canRemoveColumns\"\n class=\"menu-item\"\n (click)=\"onRemoveColumns()\">\n <mat-icon\n fontSet=\"noder-icon\"\n fontIcon=\"icon-delete\"></mat-icon>\n {{ removeMessages.removeColumnsMessage }}\n </div>\n</ng-container>\n", styles: [":host{position:absolute;border:1px solid transparent;border-radius:4px;box-shadow:0 2px 6px 2px #3c404326;overflow-y:auto;background:#fff;cursor:default;font-size:13px;margin:0;padding:6px 0}.menu-item{display:flex;flex-direction:row;align-items:center;cursor:pointer;min-height:20px;color:#202124;font-size:16px;letter-spacing:.2px;line-height:20px;padding:6px}.menu-item:hover{background-color:#0000001a}.mat-icon{margin-right:6px;width:20px;height:20px;font-size:20px}.menu-separator{-webkit-user-select:none;user-select:none}.menu-separator .menu-separator-top{padding:4px}.menu-separator .menu-separator-bottom{border-top:1px solid #dadce0;padding:4px}\n"] }]
|
|
61
|
-
}], ctorParameters: () => [{ type: i1.EditorService }, { type: i2.OverlayService }], propDecorators: { selectionRange: [{
|
|
71
|
+
}], ctorParameters: () => [{ type: i1.EditorService }, { type: i2.OverlayService }, { type: i3.TranslateService }], propDecorators: { selectionRange: [{
|
|
62
72
|
type: Input
|
|
63
73
|
}], targets: [{
|
|
64
74
|
type: Input
|
|
@@ -71,4 +81,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
71
81
|
}], sessionId: [{
|
|
72
82
|
type: Input
|
|
73
83
|
}] } });
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay-menu.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-noder/src/lib/editor/components/table/overlay-menu/overlay-menu.component.ts","../../../../../../../../projects/ngx-noder/src/lib/editor/components/table/overlay-menu/overlay-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core';\n\nimport { EditorService } from '../../../interaction/editor.service';\nimport { OverlayService } from '../../shared/services/overlay.service';\nimport { SelectionRangeModel } from '../models/selection-range.model';\n\n@Component({\n    selector: 'app-nod-table-overlay-menu',\n    templateUrl: './overlay-menu.component.html',\n    styleUrls: ['./overlay-menu.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TableOverlayMenuComponent {\n    @Input() selectionRange: SelectionRangeModel;\n\n    @Input() targets: SelectionRangeModel;\n\n    @Input() canRemoveRows: boolean;\n\n    @Input() canRemoveColumns: boolean;\n\n    @Input() tableInsertIndex: number;\n\n    @Input() sessionId: number;\n\n    selectedRowsCount: number;\n\n    selectedColumnsCount: number;\n\n    insertMessages: {\n        insertRowsAboveMessage: string;\n        insertRowsBelowMessage: string;\n        insertColumnsLeftMessage: string;\n        insertColumnsRightMessage: string;\n    };\n\n    removeMessages: {\n        removeRowsMessage: string;\n        removeColumnsMessage: string;\n    };\n\n    constructor(private editorService: EditorService, private overlayService: OverlayService) {}\n\n    ngOnInit(): void {\n        this.selectedRowsCount = this.selectionRange.rowIndexes.endIndex - this.selectionRange.rowIndexes.startIndex + 1;\n        this.selectedColumnsCount = this.selectionRange.cellIndexes.endIndex - this.selectionRange.cellIndexes.startIndex + 1;\n        this.processInsertMenuItems();\n    }\n\n    processInsertMenuItems(): void {\n        const rowsSuffix = this.selectedRowsCount > 1 ? `${this.selectedRowsCount} rows` : 'row';\n        const columnsSuffix = this.selectedColumnsCount > 1 ? `${this.selectedColumnsCount} columns` : 'column';\n        this.insertMessages = {\n            insertRowsAboveMessage: `Insert ${rowsSuffix} above`,\n            insertRowsBelowMessage: `Insert ${rowsSuffix} below`,\n            insertColumnsLeftMessage: `Insert ${columnsSuffix} to the left`,\n            insertColumnsRightMessage: `Insert ${columnsSuffix} to the right`\n        };\n        this.removeMessages = {\n            removeRowsMessage: `Remove ${rowsSuffix}`,\n            removeColumnsMessage: `Remove ${columnsSuffix}`\n        };\n    }\n\n    onInsertRowsAbove(): void {\n        this.editorService.insertTableRows(\n            this.tableInsertIndex,\n            this.selectedRowsCount,\n            this.targets.rowIndexes.startIndex,\n            this.selectionRange.rowIndexes.startIndex,\n            this.sessionId\n        );\n        this.overlayService.close();\n    }\n\n    onInsertRowsBelow(): void {\n        this.editorService.insertTableRows(\n            this.tableInsertIndex,\n            this.selectedRowsCount,\n            this.targets.rowIndexes.endIndex,\n            this.selectionRange.rowIndexes.endIndex,\n            this.sessionId\n        );\n        this.overlayService.close();\n    }\n\n    onInsertColumnsLeft(): void {\n        this.editorService.insertTableColumns(\n            this.tableInsertIndex,\n            this.selectedColumnsCount,\n            this.targets.cellIndexes.startIndex,\n            this.selectionRange.cellIndexes.startIndex,\n            this.sessionId\n        );\n        this.overlayService.close();\n    }\n\n    onInsertColumnsRight(): void {\n        this.editorService.insertTableColumns(\n            this.tableInsertIndex,\n            this.selectedColumnsCount,\n            this.targets.cellIndexes.endIndex,\n            this.selectionRange.cellIndexes.endIndex,\n            this.sessionId\n        );\n        this.overlayService.close();\n    }\n\n    onRemoveRows(): void {\n        this.editorService.removeTableRows(\n            this.tableInsertIndex,\n            this.selectionRange.rowIndexes.startIndex,\n            this.selectionRange.rowIndexes.endIndex,\n            this.sessionId\n        );\n        this.overlayService.close();\n    }\n\n    onRemoveColumns(): void {\n        this.editorService.removeTableColumns(\n            this.tableInsertIndex,\n            this.selectionRange.cellIndexes.startIndex,\n            this.selectionRange.cellIndexes.endIndex,\n            this.sessionId\n        );\n        this.overlayService.close();\n    }\n}\n","<div\n    class=\"menu-item\"\n    (click)=\"onInsertRowsAbove()\">\n    <mat-icon\n        fontSet=\"noder-icon\"\n        fontIcon=\"icon-add\"></mat-icon>\n    {{ insertMessages.insertRowsAboveMessage }}\n</div>\n<div\n    class=\"menu-item\"\n    (click)=\"onInsertRowsBelow()\">\n    <mat-icon\n        fontSet=\"noder-icon\"\n        fontIcon=\"icon-add\"></mat-icon>\n    {{ insertMessages.insertRowsBelowMessage }}\n</div>\n<div\n    class=\"menu-item\"\n    (click)=\"onInsertColumnsLeft()\">\n    <mat-icon\n        fontSet=\"noder-icon\"\n        fontIcon=\"icon-add\"></mat-icon>\n    {{ insertMessages.insertColumnsLeftMessage }}\n</div>\n<div\n    class=\"menu-item\"\n    (click)=\"onInsertColumnsRight()\">\n    <mat-icon\n        fontSet=\"noder-icon\"\n        fontIcon=\"icon-add\"></mat-icon>\n    {{ insertMessages.insertColumnsRightMessage }}\n</div>\n<ng-container *ngIf=\"canRemoveRows || canRemoveColumns\">\n    <div class=\"menu-separator\">\n        <div class=\"menu-separator-top\"></div>\n        <div class=\"menu-separator-bottom\"></div>\n    </div>\n    <div\n        *ngIf=\"canRemoveRows\"\n        class=\"menu-item\"\n        (click)=\"onRemoveRows()\">\n        <mat-icon\n            fontSet=\"noder-icon\"\n            fontIcon=\"icon-delete\"></mat-icon>\n        {{ removeMessages.removeRowsMessage }}\n    </div>\n    <div\n        *ngIf=\"canRemoveColumns\"\n        class=\"menu-item\"\n        (click)=\"onRemoveColumns()\">\n        <mat-icon\n            fontSet=\"noder-icon\"\n            fontIcon=\"icon-delete\"></mat-icon>\n        {{ removeMessages.removeColumnsMessage }}\n    </div>\n</ng-container>\n"]}
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay-menu.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-noder/src/lib/editor/components/table/overlay-menu/overlay-menu.component.ts","../../../../../../../../projects/ngx-noder/src/lib/editor/components/table/overlay-menu/overlay-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core';\nimport { TranslateService } from '@ngx-translate/core';\n\nimport { EditorService } from '../../../interaction/editor.service';\nimport { OverlayService } from '../../shared/services/overlay.service';\nimport { SelectionRangeModel } from '../models/selection-range.model';\n\n@Component({\n    selector: 'app-nod-table-overlay-menu',\n    templateUrl: './overlay-menu.component.html',\n    styleUrls: ['./overlay-menu.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TableOverlayMenuComponent {\n    @Input() selectionRange: SelectionRangeModel;\n\n    @Input() targets: SelectionRangeModel;\n\n    @Input() canRemoveRows: boolean;\n\n    @Input() canRemoveColumns: boolean;\n\n    @Input() tableInsertIndex: number;\n\n    @Input() sessionId: number;\n\n    selectedRowsCount: number;\n\n    selectedColumnsCount: number;\n\n    insertMessages: {\n        insertRowsAboveMessage: string;\n        insertRowsBelowMessage: string;\n        insertColumnsLeftMessage: string;\n        insertColumnsRightMessage: string;\n    };\n\n    removeMessages: {\n        removeRowsMessage: string;\n        removeColumnsMessage: string;\n    };\n\n    constructor(private editorService: EditorService, private overlayService: OverlayService, private translateService: TranslateService) {}\n\n    ngOnInit(): void {\n        this.selectedRowsCount = this.selectionRange.rowIndexes.endIndex - this.selectionRange.rowIndexes.startIndex + 1;\n        this.selectedColumnsCount = this.selectionRange.cellIndexes.endIndex - this.selectionRange.cellIndexes.startIndex + 1;\n        this.processInsertMenuItems();\n    }\n\n    processInsertMenuItems(): void {\n        const insertRowsAboveMessage =\n            this.selectedRowsCount > 1\n                ? this.translateService.instant('NODER.COMPLEX_LABEL.INSERT_ROWS_ABOVE', { count: this.selectedRowsCount })\n                : this.translateService.instant('NODER.LABEL.INSERT_ROW_ABOVE');\n        const insertRowsBelowMessage =\n            this.selectedRowsCount > 1\n                ? this.translateService.instant('NODER.COMPLEX_LABEL.INSERT_ROWS_BELOW', { count: this.selectedRowsCount })\n                : this.translateService.instant('NODER.LABEL.INSERT_ROW_BELOW');\n        const insertColumnsLeftMessage =\n            this.selectedRowsCount > 1\n                ? this.translateService.instant('NODER.COMPLEX_LABEL.INSERT_COLUMNS_TO_THE_LEFT', { count: this.selectedColumnsCount })\n                : this.translateService.instant('NODER.LABEL.INSERT_COLUMN_TO_THE_LEFT');\n        const insertColumnsRightMessage =\n            this.selectedRowsCount > 1\n                ? this.translateService.instant('NODER.COMPLEX_LABEL.INSERT_COLUMNS_TO_THE_RIGHT', { count: this.selectedColumnsCount })\n                : this.translateService.instant('NODER.LABEL.INSERT_COLUMN_TO_THE_RIGHT');\n        const removeRowsMessage =\n            this.selectedRowsCount > 1\n                ? this.translateService.instant('NODER.COMPLEX_LABEL.REMOVE_ROWS', { count: this.selectedRowsCount })\n                : this.translateService.instant('NODER.LABEL.REMOVE_ROW');\n        const removeColumnsMessage =\n            this.selectedRowsCount > 1\n                ? this.translateService.instant('NODER.COMPLEX_LABEL.REMOVE_COLUMNS', { count: this.selectedColumnsCount })\n                : this.translateService.instant('NODER.LABEL.REMOVE_COLUMN');\n        this.insertMessages = { insertRowsAboveMessage, insertRowsBelowMessage, insertColumnsLeftMessage, insertColumnsRightMessage };\n        this.removeMessages = { removeRowsMessage, removeColumnsMessage };\n    }\n\n    onInsertRowsAbove(): void {\n        this.editorService.insertTableRows(\n            this.tableInsertIndex,\n            this.selectedRowsCount,\n            this.targets.rowIndexes.startIndex,\n            this.selectionRange.rowIndexes.startIndex,\n            this.sessionId\n        );\n        this.overlayService.close();\n    }\n\n    onInsertRowsBelow(): void {\n        this.editorService.insertTableRows(\n            this.tableInsertIndex,\n            this.selectedRowsCount,\n            this.targets.rowIndexes.endIndex,\n            this.selectionRange.rowIndexes.endIndex,\n            this.sessionId\n        );\n        this.overlayService.close();\n    }\n\n    onInsertColumnsLeft(): void {\n        this.editorService.insertTableColumns(\n            this.tableInsertIndex,\n            this.selectedColumnsCount,\n            this.targets.cellIndexes.startIndex,\n            this.selectionRange.cellIndexes.startIndex,\n            this.sessionId\n        );\n        this.overlayService.close();\n    }\n\n    onInsertColumnsRight(): void {\n        this.editorService.insertTableColumns(\n            this.tableInsertIndex,\n            this.selectedColumnsCount,\n            this.targets.cellIndexes.endIndex,\n            this.selectionRange.cellIndexes.endIndex,\n            this.sessionId\n        );\n        this.overlayService.close();\n    }\n\n    onRemoveRows(): void {\n        this.editorService.removeTableRows(\n            this.tableInsertIndex,\n            this.selectionRange.rowIndexes.startIndex,\n            this.selectionRange.rowIndexes.endIndex,\n            this.sessionId\n        );\n        this.overlayService.close();\n    }\n\n    onRemoveColumns(): void {\n        this.editorService.removeTableColumns(\n            this.tableInsertIndex,\n            this.selectionRange.cellIndexes.startIndex,\n            this.selectionRange.cellIndexes.endIndex,\n            this.sessionId\n        );\n        this.overlayService.close();\n    }\n}\n","<div\n    class=\"menu-item\"\n    (click)=\"onInsertRowsAbove()\">\n    <mat-icon\n        fontSet=\"noder-icon\"\n        fontIcon=\"icon-add\"></mat-icon>\n    {{ insertMessages.insertRowsAboveMessage }}\n</div>\n<div\n    class=\"menu-item\"\n    (click)=\"onInsertRowsBelow()\">\n    <mat-icon\n        fontSet=\"noder-icon\"\n        fontIcon=\"icon-add\"></mat-icon>\n    {{ insertMessages.insertRowsBelowMessage }}\n</div>\n<div\n    class=\"menu-item\"\n    (click)=\"onInsertColumnsLeft()\">\n    <mat-icon\n        fontSet=\"noder-icon\"\n        fontIcon=\"icon-add\"></mat-icon>\n    {{ insertMessages.insertColumnsLeftMessage }}\n</div>\n<div\n    class=\"menu-item\"\n    (click)=\"onInsertColumnsRight()\">\n    <mat-icon\n        fontSet=\"noder-icon\"\n        fontIcon=\"icon-add\"></mat-icon>\n    {{ insertMessages.insertColumnsRightMessage }}\n</div>\n<ng-container *ngIf=\"canRemoveRows || canRemoveColumns\">\n    <div class=\"menu-separator\">\n        <div class=\"menu-separator-top\"></div>\n        <div class=\"menu-separator-bottom\"></div>\n    </div>\n    <div\n        *ngIf=\"canRemoveRows\"\n        class=\"menu-item\"\n        (click)=\"onRemoveRows()\">\n        <mat-icon\n            fontSet=\"noder-icon\"\n            fontIcon=\"icon-delete\"></mat-icon>\n        {{ removeMessages.removeRowsMessage }}\n    </div>\n    <div\n        *ngIf=\"canRemoveColumns\"\n        class=\"menu-item\"\n        (click)=\"onRemoveColumns()\">\n        <mat-icon\n            fontSet=\"noder-icon\"\n            fontIcon=\"icon-delete\"></mat-icon>\n        {{ removeMessages.removeColumnsMessage }}\n    </div>\n</ng-container>\n"]}
|
|
@@ -6,6 +6,7 @@ import { MatSidenavModule } from '@angular/material/sidenav';
|
|
|
6
6
|
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
7
7
|
import { NgModule } from '@angular/core';
|
|
8
8
|
import { ReactiveFormsModule } from '@angular/forms';
|
|
9
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
9
10
|
import { CommandsService } from './operations/commands.service';
|
|
10
11
|
import { ComponentService } from './components/shared/services/component.service';
|
|
11
12
|
import { CustomContentService } from './components/shared/services/custom-content.service';
|
|
@@ -43,8 +44,22 @@ export class EditorModule {
|
|
|
43
44
|
NoderTableCellComponent,
|
|
44
45
|
NoderTableComponent,
|
|
45
46
|
ResizerComponent,
|
|
46
|
-
TableOverlayMenuComponent], imports: [CommonModule,
|
|
47
|
-
|
|
47
|
+
TableOverlayMenuComponent], imports: [CommonModule,
|
|
48
|
+
MatButtonModule,
|
|
49
|
+
MatDialogModule,
|
|
50
|
+
MatIconModule,
|
|
51
|
+
MatSidenavModule,
|
|
52
|
+
MatTooltipModule,
|
|
53
|
+
ReactiveFormsModule,
|
|
54
|
+
TranslateModule], exports: [EditorComponent] }); }
|
|
55
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: EditorModule, providers: [ComponentService, CustomContentService, OverlayService, RegulatorService, ExternalElementService, CommandsService], imports: [CommonModule,
|
|
56
|
+
MatButtonModule,
|
|
57
|
+
MatDialogModule,
|
|
58
|
+
MatIconModule,
|
|
59
|
+
MatSidenavModule,
|
|
60
|
+
MatTooltipModule,
|
|
61
|
+
ReactiveFormsModule,
|
|
62
|
+
TranslateModule] }); }
|
|
48
63
|
}
|
|
49
64
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: EditorModule, decorators: [{
|
|
50
65
|
type: NgModule,
|
|
@@ -59,9 +74,18 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
59
74
|
ResizerComponent,
|
|
60
75
|
TableOverlayMenuComponent
|
|
61
76
|
],
|
|
62
|
-
imports: [
|
|
77
|
+
imports: [
|
|
78
|
+
CommonModule,
|
|
79
|
+
MatButtonModule,
|
|
80
|
+
MatDialogModule,
|
|
81
|
+
MatIconModule,
|
|
82
|
+
MatSidenavModule,
|
|
83
|
+
MatTooltipModule,
|
|
84
|
+
ReactiveFormsModule,
|
|
85
|
+
TranslateModule
|
|
86
|
+
],
|
|
63
87
|
providers: [ComponentService, CustomContentService, OverlayService, RegulatorService, ExternalElementService, CommandsService],
|
|
64
88
|
exports: [EditorComponent]
|
|
65
89
|
}]
|
|
66
90
|
}] });
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.module.js","sourceRoot":"","sources":["../../../../../projects/ngx-noder/src/lib/editor/editor.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatDialogModule } from '@angular/material/dialog';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatSidenavModule } from '@angular/material/sidenav';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { ModuleWithProviders, NgModule, Type } from '@angular/core';\nimport { ReactiveFormsModule } from '@angular/forms';\nimport { TranslateModule } from '@ngx-translate/core';\n\nimport { CommandsService } from './operations/commands.service';\nimport { ComponentService } from './components/shared/services/component.service';\nimport { CustomContentService } from './components/shared/services/custom-content.service';\nimport { DefaultImageApiService, ImageApiService } from './components/image/image-api.service';\nimport { EditorComponent } from './components/editor.component';\nimport { EXTERNAL_ELEMENT_SERVICE, EXTERNAL_ELEMENT_SIDENAV } from '../editor/components/external-element/external-elements.const';\nimport { ExternalElementInterface, ExternalElementService } from '../editor/components/external-element/external-element.service';\nimport { ExternalSidenavModel } from './components/external-element/models/external-sidenav.model';\nimport { NoderEdgeComponent } from './components/edges/edge.component';\nimport { NoderImageComponent } from './components/image/components/image.component';\nimport { NoderTabComponent } from './components/tab/tab.component';\nimport { NoderTableCellComponent } from './components/table/components/table-cell.component';\nimport { NoderTableComponent } from './components/table/components/table.component';\nimport { OverlayService } from './components/shared/services/overlay.service';\nimport { RegulatorService } from './execution/regulator.service';\nimport { ResizerComponent } from './components/image/resizer/resizer.component';\nimport { TableOverlayMenuComponent } from './components/table/overlay-menu/overlay-menu.component';\n\nexport interface INoderOptions {\n    sidenav?: Partial<ExternalSidenavModel>;\n    imageApiService?: Type<ImageApiService>;\n    elementService: Type<ExternalElementInterface>;\n}\n\n@NgModule({\n    declarations: [\n        EditorComponent,\n        NoderEdgeComponent,\n        NoderImageComponent,\n        NoderTabComponent,\n        NoderTableCellComponent,\n        NoderTableComponent,\n        ResizerComponent,\n        TableOverlayMenuComponent\n    ],\n    imports: [\n        CommonModule,\n        MatButtonModule,\n        MatDialogModule,\n        MatIconModule,\n        MatSidenavModule,\n        MatTooltipModule,\n        ReactiveFormsModule,\n        TranslateModule\n    ],\n    providers: [ComponentService, CustomContentService, OverlayService, RegulatorService, ExternalElementService, CommandsService],\n    exports: [EditorComponent]\n})\nexport class EditorModule {\n    static forRoot(options?: INoderOptions): ModuleWithProviders<EditorModule> {\n        return {\n            ngModule: EditorModule,\n            providers: [\n                { provide: EXTERNAL_ELEMENT_SIDENAV, useValue: new ExternalSidenavModel(options?.sidenav) },\n                { provide: EXTERNAL_ELEMENT_SERVICE, useClass: options?.elementService ?? ExternalElementService },\n                { provide: ImageApiService, useClass: options?.imageApiService ?? DefaultImageApiService }\n            ]\n        };\n    }\n}\n"]}
|