@talrace/ngx-noder 0.0.3 → 0.0.5
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 -64
- package/esm2022/lib/+shared/add-link-dialog/add-link-dialog.component.mjs +9 -5
- package/esm2022/lib/+shared/confirm-dialog/confirm-dialog.component.mjs +10 -6
- package/esm2022/lib/+shared/editor/core/editor.mjs +7 -14
- package/esm2022/lib/+shared/editor/core/helpers/rendering.helper.mjs +9 -8
- package/esm2022/lib/+shared/editor/core/layers/text.layer.mjs +4 -4
- package/esm2022/lib/+shared/editor/custom-components/image/components/image.component.mjs +4 -3
- package/esm2022/lib/+shared/editor/custom-components/shared/abstract/base.component.mjs +4 -2
- package/esm2022/lib/+shared/editor/custom-components/shared/services/custom-content/custom-content.service.mjs +6 -12
- package/esm2022/lib/+shared/editor/custom-components/tab/tab.component.mjs +3 -2
- package/esm2022/lib/+shared/editor/custom-components/table/components/table-cell.component.mjs +6 -4
- package/esm2022/lib/+shared/editor/custom-components/table/components/table.component.mjs +7 -5
- package/esm2022/lib/+shared/editor/editor.component.mjs +5 -12
- package/esm2022/lib/+shared/editor/editor.module.mjs +1 -4
- package/esm2022/lib/+shared/editor/execution/models/general-properties.model.mjs +1 -1
- package/esm2022/lib/+shared/editor/execution/regulator.service.mjs +15 -5
- package/esm2022/lib/+shared/editor-title/editor-title.component.mjs +83 -0
- package/esm2022/lib/+shared/editor-toolbar/color-picker/color-picker.component.mjs +2 -2
- package/esm2022/lib/+shared/editor-toolbar/editor-toolbar.component.mjs +77 -91
- package/esm2022/lib/+shared/editor-toolbar/editor-toolbar.module.mjs +11 -1
- package/esm2022/lib/+shared/editor-toolbar/font/font.component.mjs +3 -3
- package/esm2022/lib/+shared/editor-toolbar/font-size/font-size.component.mjs +2 -2
- package/esm2022/lib/+shared/editor-toolbar/font-style/font-style.component.mjs +2 -2
- package/esm2022/lib/+shared/editor-toolbar/menu-dropdowns/menu-dropdowns.component.mjs +194 -0
- package/esm2022/lib/+shared/editor-toolbar/numbering/numbering.component.mjs +3 -3
- package/esm2022/lib/+shared/editor-toolbar/print/print.component.mjs +2 -2
- package/esm2022/lib/+shared/editor-toolbar/toolbar-actions/toolbar-actions.component.mjs +126 -0
- package/esm2022/lib/+shared/editor-toolbar/undo-redo/undo-redo.component.mjs +2 -2
- package/esm2022/lib/+shared/helpers/scaling.helper.mjs +9 -0
- package/esm2022/public-api.mjs +2 -2
- package/fesm2022/talrace-ngx-noder.mjs +455 -398
- package/fesm2022/talrace-ngx-noder.mjs.map +1 -1
- package/lib/+shared/add-link-dialog/add-link-dialog.component.d.ts +1 -0
- package/lib/+shared/confirm-dialog/confirm-dialog.component.d.ts +1 -0
- package/lib/+shared/editor/core/editor.d.ts +3 -3
- package/lib/+shared/editor/core/helpers/rendering.helper.d.ts +3 -3
- package/lib/+shared/editor/custom-components/shared/abstract/base.component.d.ts +3 -1
- package/lib/+shared/editor/custom-components/shared/services/custom-content/custom-content.service.d.ts +1 -1
- package/lib/+shared/editor/custom-components/table/components/table-cell.component.d.ts +2 -2
- package/lib/+shared/editor/custom-components/table/components/table.component.d.ts +0 -2
- package/lib/+shared/editor/editor.component.d.ts +1 -5
- package/lib/+shared/editor/editor.module.d.ts +15 -16
- package/lib/+shared/editor/execution/models/general-properties.model.d.ts +1 -0
- package/lib/+shared/editor/execution/regulator.service.d.ts +2 -2
- package/lib/+shared/editor-title/editor-title.component.d.ts +24 -0
- package/lib/+shared/editor-toolbar/editor-toolbar.component.d.ts +31 -30
- package/lib/+shared/editor-toolbar/editor-toolbar.module.d.ts +19 -16
- package/lib/+shared/editor-toolbar/menu-dropdowns/menu-dropdowns.component.d.ts +73 -0
- package/lib/+shared/editor-toolbar/toolbar-actions/toolbar-actions.component.d.ts +49 -0
- package/lib/+shared/helpers/scaling.helper.d.ts +4 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -1
- package/src/_ngx-noder.theme.scss +10 -8
- package/src/lib/+shared/add-link-dialog/_add-link-dialog.theme.scss +3 -3
- package/src/lib/+shared/confirm-dialog/_theme.scss +6 -6
- package/src/lib/+shared/editor/_editor.theme.scss +84 -15
- package/src/lib/+shared/editor/_theme.scss +0 -2
- package/src/lib/+shared/editor-title/_editor-title.theme.scss +28 -0
- package/src/lib/+shared/editor-toolbar/_editor-toolbar.theme.scss +1 -24
- package/src/lib/+shared/editor-toolbar/_theme.scss +14 -2
- package/src/lib/+shared/editor-toolbar/font-size/_font-size.theme.scss +14 -0
- package/src/lib/+shared/editor-toolbar/font-style/_font-style.theme.scss +21 -0
- package/src/lib/+shared/editor-toolbar/format/_format.theme.scss +21 -0
- package/src/lib/+shared/editor-toolbar/menu-dropdowns/_menu-dropdowns.theme.scss +22 -0
- package/src/lib/+shared/editor-toolbar/numbering/_numbering.theme.scss +52 -11
- package/src/lib/+shared/editor-toolbar/toolbar-actions/_toolbar-actions.theme.scss +21 -0
- package/src/lib/+shared/editor-toolbar/undo-redo/_undo-redo.theme.scss +16 -0
- package/src/lib/+shared/insert-table/_insert-table.theme.scss +9 -6
- package/src/scss/_mixins.scss +2 -37
- package/esm2022/lib/+shared/editor/custom-components/external-element/element-toolbar/element-toolbar.component.mjs +0 -35
- package/esm2022/lib/+shared/editor-header/editor-header.component.mjs +0 -314
- package/lib/+shared/editor/custom-components/external-element/element-toolbar/element-toolbar.component.d.ts +0 -14
- package/lib/+shared/editor-header/editor-header.component.d.ts +0 -101
- package/src/lib/+shared/editor/custom-components/external-element/element-toolbar/_element-toolbar.theme.scss +0 -10
- package/src/lib/+shared/editor-header/_editor-header.theme.scss +0 -106
|
@@ -2,7 +2,7 @@ import { ChangeDetectionStrategy, Component, HostBinding, Input, ViewChild } fro
|
|
|
2
2
|
import { DocxModel } from '../../models/generated/docx.model';
|
|
3
3
|
import { Editor } from './core/editor';
|
|
4
4
|
import { EDITOR_VERSION } from './core/constants/editor-version.const';
|
|
5
|
-
import {
|
|
5
|
+
import { EXTERNAL_ELEMENT_SIDENAV } from './custom-components/external-element/external-elements.const';
|
|
6
6
|
import { FontMetrics } from './core/helpers/font-metrics.helper';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
import * as i1 from "./custom-components/shared/services/component/component.service";
|
|
@@ -10,9 +10,7 @@ import * as i2 from "./interaction/editor.service";
|
|
|
10
10
|
import * as i3 from "./execution/regulator.service";
|
|
11
11
|
import * as i4 from "../services/commands.service";
|
|
12
12
|
import * as i5 from "@angular/cdk/clipboard";
|
|
13
|
-
import * as i6 from "@angular/
|
|
14
|
-
import * as i7 from "@angular/material/sidenav";
|
|
15
|
-
import * as i8 from "./custom-components/external-element/element-toolbar/element-toolbar.component";
|
|
13
|
+
import * as i6 from "@angular/material/sidenav";
|
|
16
14
|
export class EditorComponent {
|
|
17
15
|
get isViewOnly$() {
|
|
18
16
|
return this.editorService.isViewOnly$;
|
|
@@ -38,7 +36,6 @@ export class EditorComponent {
|
|
|
38
36
|
this.class = 'base-editor';
|
|
39
37
|
this.subscriptions = [];
|
|
40
38
|
this.sidenavComponentRef = null;
|
|
41
|
-
this.elements = this.injector.get(EXTERNAL_ELEMENT_SERVICE).elements;
|
|
42
39
|
this.sidenavProperties = this.injector.get(EXTERNAL_ELEMENT_SIDENAV);
|
|
43
40
|
FontMetrics.checkVersion(EDITOR_VERSION);
|
|
44
41
|
}
|
|
@@ -53,10 +50,6 @@ export class EditorComponent {
|
|
|
53
50
|
this.editor = new Editor(content, this.container, this.editorService, this.regulatorService, this.commandsService, this.clipboard, this.customPageWidth);
|
|
54
51
|
this.subscriptions.push(this.toggleSidenavSubscription());
|
|
55
52
|
}
|
|
56
|
-
createElement(model) {
|
|
57
|
-
this.editor.createCustomElement(model);
|
|
58
|
-
this.editor.focus();
|
|
59
|
-
}
|
|
60
53
|
toggleSidenavSubscription() {
|
|
61
54
|
return this.editorService.toggleSidenav$.subscribe(data => {
|
|
62
55
|
if (this.sidenav.opened === data.open) {
|
|
@@ -80,11 +73,11 @@ export class EditorComponent {
|
|
|
80
73
|
});
|
|
81
74
|
}
|
|
82
75
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: EditorComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.ComponentService }, { token: i2.EditorService }, { token: i0.Injector }, { token: i3.RegulatorService }, { token: i4.CommandsService }, { token: i5.Clipboard }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
83
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: EditorComponent, selector: "app-editor", inputs: { customPageWidth: "customPageWidth", content: "content" }, host: { properties: { "class": "this.class" } }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true, static: true }, { propertyName: "sidenavContainer", first: true, predicate: ["drawerContainer"], descendants: true, static: true }, { propertyName: "sidenav", first: true, predicate: ["drawer"], descendants: true, static: true }], ngImport: i0, template: "<mat-drawer-container\n class=\"sidenav-container\"\n [hasBackdrop]=\"sidenavProperties.hasBackdrop\">\n <mat-drawer-content>\n <div class=\"container\">\n <div\n #container\n class=\"edit-container\"></div>\n
|
|
76
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: EditorComponent, selector: "app-editor", inputs: { customPageWidth: "customPageWidth", content: "content" }, host: { properties: { "class": "this.class" } }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true, static: true }, { propertyName: "sidenavContainer", first: true, predicate: ["drawerContainer"], descendants: true, static: true }, { propertyName: "sidenav", first: true, predicate: ["drawer"], descendants: true, static: true }], ngImport: i0, template: "<mat-drawer-container\n class=\"sidenav-container\"\n [hasBackdrop]=\"sidenavProperties.hasBackdrop\">\n <mat-drawer-content>\n <div class=\"container\">\n <div\n #container\n class=\"edit-container\"></div>\n </div>\n </mat-drawer-content>\n <mat-drawer\n #drawer\n [autoFocus]=\"sidenavProperties.autoFocus\"\n [position]=\"sidenavProperties.position\"\n [mode]=\"sidenavProperties.mode\">\n <div\n #drawerContainer\n class=\"drawer-container\"></div>\n </mat-drawer>\n</mat-drawer-container>\n", styles: [":host{flex:1;display:flex;position:relative}.sidenav-container{width:100%}.container{height:100%;display:flex;justify-content:center}:host::ng-deep .ace-editor{position:relative;line-height:1;font-size:12pt;font-family:Courier New,Courier,monospace;text-align:left;width:100%;height:100%}:host::ng-deep .ace-scroller{position:absolute;overflow:hidden;top:0;bottom:0;-webkit-user-select:none;user-select:none;cursor:text}:host::ng-deep .ace-scrollbar{overflow:hidden scroll;contain:strict;position:absolute;right:0;bottom:0;z-index:6;top:0}:host::ng-deep .ace-scrollbar-inner{position:absolute;cursor:text;left:0;top:0}:host::ng-deep .ace-text-input{position:absolute;z-index:0;width:.5em;height:1em;opacity:0;background:transparent;appearance:none;border:none;resize:none;overflow:hidden;font:inherit;padding:0 1px;margin:0 -1px;contain:strict;-webkit-user-select:text;user-select:text}:host::ng-deep .ace-layer{z-index:1;position:absolute;word-wrap:normal;white-space:pre;height:100%;width:100%;box-sizing:border-box;pointer-events:none}:host::ng-deep .ace-text-layer{font:inherit!important;position:absolute;contain:style size layout;pointer-events:auto}:host::ng-deep .ace-edges-layer{z-index:2}:host::ng-deep .ace-line{display:flex;align-items:baseline;line-height:normal}:host::ng-deep .ace-line .hyperlink-hover{cursor:pointer}:host::ng-deep .ace-line>*{display:inline-block;font-kerning:none}:host::ng-deep .ace-line>*.paragraph-symbol{align-self:flex-end}:host::ng-deep .ace-content{position:inherit;box-sizing:border-box;min-width:100%;contain:style size layout;inset:0}:host::ng-deep .ace-line-group{display:inline-flex}:host::ng-deep .ace-line-group .lines-container{width:100%}:host::ng-deep .ace-line-group .numberingMarker{display:inline-flex}:host::ng-deep .ace-line-group .numberingMarker span{align-self:end}:host::ng-deep .ace-text-layer>.ace-line,:host::ng-deep .ace-text-layer>.ace-line-group,:host::ng-deep .ace-edges-layer>.ace-line,:host::ng-deep .ace-edges-layer>.ace-line-group{contain:style size layout;position:absolute;top:0;left:0;right:0}:host::ng-deep .ace-text-layer>.ace-line-group:has(.focused){z-index:1}:host::ng-deep .ace-line-group:has(.lines-container>.ace-line:first-child>span:not(:empty)){align-items:baseline}:host::ng-deep .ace-cursor-layer{z-index:4}:host::ng-deep .ace-cursor-layer.selecting{display:none}:host::ng-deep .ace-cursor{z-index:4;position:absolute;box-sizing:border-box;border-left:2px solid;transform:translateZ(0)}:host::ng-deep .ace-hidden-cursors .ace-cursor{opacity:0}:host::ng-deep .ace-hidden-cursors{visibility:hidden}:host::ng-deep .ace-animate-blinking .ace-cursor{animation-duration:1s;animation-timing-function:step-end;animation-name:blink-ace-animate;animation-iteration-count:infinite}:host::ng-deep .ace-animate-blinking.ace-smooth-blinking .ace-cursor{animation-duration:1s;animation-timing-function:ease-in-out;animation-name:blink-ace-animate-smooth}@keyframes blink-ace-animate{0%,to{opacity:1}60%{opacity:0}}@keyframes blink-ace-animate-smooth{0%,to{opacity:1}45%{opacity:1}60%{opacity:0}85%{opacity:0}}:host::ng-deep .ace-selection-layer .ace-selection{position:absolute;z-index:5}:host::ng-deep .ace-selection-layer.text-selection .ace-selection{background-color:#5ea8f766}:host::ng-deep .ace-selection-layer.notes-highlight .ace-selection{background:#ff06}:host::ng-deep .ace-underline{text-decoration:underline}:host::ng-deep .ace-bold{font-weight:700}:host::ng-deep .ace-italic{font-style:italic}:host::ng-deep .page{width:100%;position:absolute}:host::ng-deep .page-label{position:absolute;top:40px;right:96px;font-family:Courier New,Courier,monospace;font-size:16px;line-height:1}:host::ng-deep .font-baseline{visibility:hidden;height:500px}:host::ng-deep .font-baseline span:after{content:\"\";height:100%;display:inline-block}:host::ng-deep .ruler-line{position:absolute;top:0;bottom:0;width:0;border-left:1px solid rgba(0,0,0,.4);opacity:.5;display:none;z-index:1}:host::ng-deep .ruler-line.visible{display:block}:host::ng-deep .drawer-container .mat-button-toggle-button{height:48px;border-radius:4px}:host::ng-deep .drawer-container .mat-button-toggle-checked button{height:48px;border-radius:4px}\n"], dependencies: [{ kind: "component", type: i6.MatDrawer, selector: "mat-drawer", inputs: ["position", "mode", "disableClose", "autoFocus", "opened"], outputs: ["openedChange", "opened", "openedStart", "closed", "closedStart", "positionChanged"], exportAs: ["matDrawer"] }, { kind: "component", type: i6.MatDrawerContainer, selector: "mat-drawer-container", inputs: ["autosize", "hasBackdrop"], outputs: ["backdropClick"], exportAs: ["matDrawerContainer"] }, { kind: "component", type: i6.MatDrawerContent, selector: "mat-drawer-content" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
84
77
|
}
|
|
85
78
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: EditorComponent, decorators: [{
|
|
86
79
|
type: Component,
|
|
87
|
-
args: [{ selector: 'app-editor', changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-drawer-container\n class=\"sidenav-container\"\n [hasBackdrop]=\"sidenavProperties.hasBackdrop\">\n <mat-drawer-content>\n <div class=\"container\">\n <div\n #container\n class=\"edit-container\"></div>\n
|
|
80
|
+
args: [{ selector: 'app-editor', changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-drawer-container\n class=\"sidenav-container\"\n [hasBackdrop]=\"sidenavProperties.hasBackdrop\">\n <mat-drawer-content>\n <div class=\"container\">\n <div\n #container\n class=\"edit-container\"></div>\n </div>\n </mat-drawer-content>\n <mat-drawer\n #drawer\n [autoFocus]=\"sidenavProperties.autoFocus\"\n [position]=\"sidenavProperties.position\"\n [mode]=\"sidenavProperties.mode\">\n <div\n #drawerContainer\n class=\"drawer-container\"></div>\n </mat-drawer>\n</mat-drawer-container>\n", styles: [":host{flex:1;display:flex;position:relative}.sidenav-container{width:100%}.container{height:100%;display:flex;justify-content:center}:host::ng-deep .ace-editor{position:relative;line-height:1;font-size:12pt;font-family:Courier New,Courier,monospace;text-align:left;width:100%;height:100%}:host::ng-deep .ace-scroller{position:absolute;overflow:hidden;top:0;bottom:0;-webkit-user-select:none;user-select:none;cursor:text}:host::ng-deep .ace-scrollbar{overflow:hidden scroll;contain:strict;position:absolute;right:0;bottom:0;z-index:6;top:0}:host::ng-deep .ace-scrollbar-inner{position:absolute;cursor:text;left:0;top:0}:host::ng-deep .ace-text-input{position:absolute;z-index:0;width:.5em;height:1em;opacity:0;background:transparent;appearance:none;border:none;resize:none;overflow:hidden;font:inherit;padding:0 1px;margin:0 -1px;contain:strict;-webkit-user-select:text;user-select:text}:host::ng-deep .ace-layer{z-index:1;position:absolute;word-wrap:normal;white-space:pre;height:100%;width:100%;box-sizing:border-box;pointer-events:none}:host::ng-deep .ace-text-layer{font:inherit!important;position:absolute;contain:style size layout;pointer-events:auto}:host::ng-deep .ace-edges-layer{z-index:2}:host::ng-deep .ace-line{display:flex;align-items:baseline;line-height:normal}:host::ng-deep .ace-line .hyperlink-hover{cursor:pointer}:host::ng-deep .ace-line>*{display:inline-block;font-kerning:none}:host::ng-deep .ace-line>*.paragraph-symbol{align-self:flex-end}:host::ng-deep .ace-content{position:inherit;box-sizing:border-box;min-width:100%;contain:style size layout;inset:0}:host::ng-deep .ace-line-group{display:inline-flex}:host::ng-deep .ace-line-group .lines-container{width:100%}:host::ng-deep .ace-line-group .numberingMarker{display:inline-flex}:host::ng-deep .ace-line-group .numberingMarker span{align-self:end}:host::ng-deep .ace-text-layer>.ace-line,:host::ng-deep .ace-text-layer>.ace-line-group,:host::ng-deep .ace-edges-layer>.ace-line,:host::ng-deep .ace-edges-layer>.ace-line-group{contain:style size layout;position:absolute;top:0;left:0;right:0}:host::ng-deep .ace-text-layer>.ace-line-group:has(.focused){z-index:1}:host::ng-deep .ace-line-group:has(.lines-container>.ace-line:first-child>span:not(:empty)){align-items:baseline}:host::ng-deep .ace-cursor-layer{z-index:4}:host::ng-deep .ace-cursor-layer.selecting{display:none}:host::ng-deep .ace-cursor{z-index:4;position:absolute;box-sizing:border-box;border-left:2px solid;transform:translateZ(0)}:host::ng-deep .ace-hidden-cursors .ace-cursor{opacity:0}:host::ng-deep .ace-hidden-cursors{visibility:hidden}:host::ng-deep .ace-animate-blinking .ace-cursor{animation-duration:1s;animation-timing-function:step-end;animation-name:blink-ace-animate;animation-iteration-count:infinite}:host::ng-deep .ace-animate-blinking.ace-smooth-blinking .ace-cursor{animation-duration:1s;animation-timing-function:ease-in-out;animation-name:blink-ace-animate-smooth}@keyframes blink-ace-animate{0%,to{opacity:1}60%{opacity:0}}@keyframes blink-ace-animate-smooth{0%,to{opacity:1}45%{opacity:1}60%{opacity:0}85%{opacity:0}}:host::ng-deep .ace-selection-layer .ace-selection{position:absolute;z-index:5}:host::ng-deep .ace-selection-layer.text-selection .ace-selection{background-color:#5ea8f766}:host::ng-deep .ace-selection-layer.notes-highlight .ace-selection{background:#ff06}:host::ng-deep .ace-underline{text-decoration:underline}:host::ng-deep .ace-bold{font-weight:700}:host::ng-deep .ace-italic{font-style:italic}:host::ng-deep .page{width:100%;position:absolute}:host::ng-deep .page-label{position:absolute;top:40px;right:96px;font-family:Courier New,Courier,monospace;font-size:16px;line-height:1}:host::ng-deep .font-baseline{visibility:hidden;height:500px}:host::ng-deep .font-baseline span:after{content:\"\";height:100%;display:inline-block}:host::ng-deep .ruler-line{position:absolute;top:0;bottom:0;width:0;border-left:1px solid rgba(0,0,0,.4);opacity:.5;display:none;z-index:1}:host::ng-deep .ruler-line.visible{display:block}:host::ng-deep .drawer-container .mat-button-toggle-button{height:48px;border-radius:4px}:host::ng-deep .drawer-container .mat-button-toggle-checked button{height:48px;border-radius:4px}\n"] }]
|
|
88
81
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.ComponentService }, { type: i2.EditorService }, { type: i0.Injector }, { type: i3.RegulatorService }, { type: i4.CommandsService }, { type: i5.Clipboard }], propDecorators: { customPageWidth: [{
|
|
89
82
|
type: Input
|
|
90
83
|
}], content: [{
|
|
@@ -102,4 +95,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImpor
|
|
|
102
95
|
type: HostBinding,
|
|
103
96
|
args: ['class']
|
|
104
97
|
}] } });
|
|
105
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-noder/src/lib/+shared/editor/editor.component.ts","../../../../../../projects/ngx-noder/src/lib/+shared/editor/editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ComponentRef,\n    ElementRef,\n    HostBinding,\n    Injector,\n    Input,\n    OnDestroy,\n    ViewChild\n} from '@angular/core';\nimport { Clipboard } from '@angular/cdk/clipboard';\nimport { MatDrawer } from '@angular/material/sidenav';\nimport { Observable, Subscription } from 'rxjs';\n\nimport { CommandsService } from '../services/commands.service';\nimport { ComponentService } from './custom-components/shared/services/component/component.service';\nimport { DocxModel } from '../../models/generated/docx.model';\nimport { Editor } from './core/editor';\nimport { EDITOR_VERSION } from './core/constants/editor-version.const';\nimport { EditorService } from './interaction/editor.service';\nimport { ElementDataModel } from './custom-components/external-element/models/element-data.model';\nimport { EXTERNAL_ELEMENT_SERVICE, EXTERNAL_ELEMENT_SIDENAV } from './custom-components/external-element/external-elements.const';\nimport { ExternalElementModel } from './custom-components/external-element/models/external-element.model';\nimport { ExternalSidenavModel } from './custom-components/external-element/models/external-sidenav.model';\nimport { FontMetrics } from './core/helpers/font-metrics.helper';\nimport { RegulatorService } from './execution/regulator.service';\n\n@Component({\n    selector: 'app-editor',\n    templateUrl: './editor.component.html',\n    styleUrls: ['./editor.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class EditorComponent implements OnDestroy {\n    get isViewOnly$(): Observable<boolean> {\n        return this.editorService.isViewOnly$;\n    }\n\n    @Input() customPageWidth?: number;\n\n    @Input()\n    set content(model: DocxModel) {\n        if (model) {\n            const deepCopy = JSON.parse(JSON.stringify(model));\n            this._content = new DocxModel(deepCopy as DocxModel);\n        }\n\n        this.initEditor(this._content);\n    }\n    get content(): DocxModel {\n        return this._content;\n    }\n    private _content: DocxModel;\n\n    @ViewChild('container', { static: true }) container: ElementRef<HTMLElement>;\n\n    @ViewChild('drawerContainer', { static: true }) sidenavContainer: ElementRef<HTMLElement>;\n\n    @ViewChild('drawer', { static: true }) sidenav: MatDrawer;\n\n    @HostBinding('class') class = 'base-editor';\n\n    editor: Editor;\n\n    elements: ExternalElementModel[];\n\n    sidenavProperties: ExternalSidenavModel;\n\n    readonly subscriptions: Subscription[] = [];\n\n    private sidenavComponentRef: ComponentRef<any> | null = null;\n\n    constructor(\n        private cdr: ChangeDetectorRef,\n        private componentService: ComponentService,\n        private editorService: EditorService,\n        private injector: Injector,\n        private regulatorService: RegulatorService,\n        private commandsService: CommandsService,\n        private clipboard: Clipboard\n    ) {\n        this.elements = this.injector.get(EXTERNAL_ELEMENT_SERVICE).elements;\n        this.sidenavProperties = this.injector.get(EXTERNAL_ELEMENT_SIDENAV);\n        FontMetrics.checkVersion(EDITOR_VERSION);\n    }\n\n    ngOnDestroy(): void {\n        this.editor?.destroy();\n        this.regulatorService.clearAllSessions();\n        this.subscriptions.forEach(x => x?.unsubscribe());\n        this.subscriptions.splice(0);\n    }\n\n    initEditor(content: DocxModel): void {\n        this.ngOnDestroy();\n        this.editor = new Editor(\n            content,\n            this.container,\n            this.editorService,\n            this.regulatorService,\n            this.commandsService,\n            this.clipboard,\n            this.customPageWidth\n        );\n        this.subscriptions.push(this.toggleSidenavSubscription());\n    }\n\n    createElement(model: ElementDataModel) {\n        this.editor.createCustomElement(model);\n        this.editor.focus();\n    }\n\n    toggleSidenavSubscription(): Subscription {\n        return this.editorService.toggleSidenav$.subscribe(data => {\n            if (this.sidenav.opened === data.open) {\n                return;\n            }\n            if (data.open) {\n                this.sidenavComponentRef = this.componentService.createComponent(data.component, {\n                    model: data.model,\n                    contentWidth: data.contentWidth\n                });\n                this.componentService.attachComponent(this.sidenavContainer.nativeElement, this.sidenavComponentRef);\n            } else {\n                this.componentService.removeComponent(this.sidenavComponentRef);\n                this.sidenavComponentRef = null;\n            }\n            this.sidenav.toggle().catch(() => {\n                // continue regardless of error\n            });\n            this.cdr.markForCheck();\n        });\n    }\n}\n","<mat-drawer-container\n    class=\"sidenav-container\"\n    [hasBackdrop]=\"sidenavProperties.hasBackdrop\">\n    <mat-drawer-content>\n        <div class=\"container\">\n            <div\n                #container\n                class=\"edit-container\"></div>\n            <app-element-toolbar\n                *ngIf=\"elements.length\"\n                [elements]=\"elements\"\n                [isDisabled]=\"isViewOnly$ | async\"\n                (createElement)=\"createElement($event)\"></app-element-toolbar>\n        </div>\n    </mat-drawer-content>\n    <mat-drawer\n        #drawer\n        [autoFocus]=\"sidenavProperties.autoFocus\"\n        [position]=\"sidenavProperties.position\"\n        [mode]=\"sidenavProperties.mode\">\n        <div\n            #drawerContainer\n            class=\"drawer-container\"></div>\n    </mat-drawer>\n</mat-drawer-container>\n"]}
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-noder/src/lib/+shared/editor/editor.component.ts","../../../../../../projects/ngx-noder/src/lib/+shared/editor/editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ComponentRef,\n    ElementRef,\n    HostBinding,\n    Injector,\n    Input,\n    OnDestroy,\n    ViewChild\n} from '@angular/core';\nimport { Clipboard } from '@angular/cdk/clipboard';\nimport { MatDrawer } from '@angular/material/sidenav';\nimport { Observable, Subscription } from 'rxjs';\n\nimport { CommandsService } from '../services/commands.service';\nimport { ComponentService } from './custom-components/shared/services/component/component.service';\nimport { DocxModel } from '../../models/generated/docx.model';\nimport { Editor } from './core/editor';\nimport { EDITOR_VERSION } from './core/constants/editor-version.const';\nimport { EditorService } from './interaction/editor.service';\nimport { EXTERNAL_ELEMENT_SIDENAV } from './custom-components/external-element/external-elements.const';\nimport { ExternalSidenavModel } from './custom-components/external-element/models/external-sidenav.model';\nimport { FontMetrics } from './core/helpers/font-metrics.helper';\nimport { RegulatorService } from './execution/regulator.service';\n\n@Component({\n    selector: 'app-editor',\n    templateUrl: './editor.component.html',\n    styleUrls: ['./editor.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class EditorComponent implements OnDestroy {\n    get isViewOnly$(): Observable<boolean> {\n        return this.editorService.isViewOnly$;\n    }\n\n    @Input() customPageWidth?: number | null;\n\n    @Input()\n    set content(model: DocxModel) {\n        if (model) {\n            const deepCopy = JSON.parse(JSON.stringify(model));\n            this._content = new DocxModel(deepCopy as DocxModel);\n        }\n\n        this.initEditor(this._content);\n    }\n    get content(): DocxModel {\n        return this._content;\n    }\n    private _content: DocxModel;\n\n    @ViewChild('container', { static: true }) container: ElementRef<HTMLElement>;\n\n    @ViewChild('drawerContainer', { static: true }) sidenavContainer: ElementRef<HTMLElement>;\n\n    @ViewChild('drawer', { static: true }) sidenav: MatDrawer;\n\n    @HostBinding('class') class = 'base-editor';\n\n    editor: Editor;\n\n    sidenavProperties: ExternalSidenavModel;\n\n    readonly subscriptions: Subscription[] = [];\n\n    private sidenavComponentRef: ComponentRef<any> | null = null;\n\n    constructor(\n        private cdr: ChangeDetectorRef,\n        private componentService: ComponentService,\n        private editorService: EditorService,\n        private injector: Injector,\n        private regulatorService: RegulatorService,\n        private commandsService: CommandsService,\n        private clipboard: Clipboard\n    ) {\n        this.sidenavProperties = this.injector.get(EXTERNAL_ELEMENT_SIDENAV);\n        FontMetrics.checkVersion(EDITOR_VERSION);\n    }\n\n    ngOnDestroy(): void {\n        this.editor?.destroy();\n        this.regulatorService.clearAllSessions();\n        this.subscriptions.forEach(x => x?.unsubscribe());\n        this.subscriptions.splice(0);\n    }\n\n    initEditor(content: DocxModel): void {\n        this.ngOnDestroy();\n        this.editor = new Editor(\n            content,\n            this.container,\n            this.editorService,\n            this.regulatorService,\n            this.commandsService,\n            this.clipboard,\n            this.customPageWidth\n        );\n        this.subscriptions.push(this.toggleSidenavSubscription());\n    }\n\n    toggleSidenavSubscription(): Subscription {\n        return this.editorService.toggleSidenav$.subscribe(data => {\n            if (this.sidenav.opened === data.open) {\n                return;\n            }\n            if (data.open) {\n                this.sidenavComponentRef = this.componentService.createComponent(data.component, {\n                    model: data.model,\n                    contentWidth: data.contentWidth\n                });\n                this.componentService.attachComponent(this.sidenavContainer.nativeElement, this.sidenavComponentRef);\n            } else {\n                this.componentService.removeComponent(this.sidenavComponentRef);\n                this.sidenavComponentRef = null;\n            }\n            this.sidenav.toggle().catch(() => {\n                // continue regardless of error\n            });\n            this.cdr.markForCheck();\n        });\n    }\n}\n","<mat-drawer-container\n    class=\"sidenav-container\"\n    [hasBackdrop]=\"sidenavProperties.hasBackdrop\">\n    <mat-drawer-content>\n        <div class=\"container\">\n            <div\n                #container\n                class=\"edit-container\"></div>\n        </div>\n    </mat-drawer-content>\n    <mat-drawer\n        #drawer\n        [autoFocus]=\"sidenavProperties.autoFocus\"\n        [position]=\"sidenavProperties.position\"\n        [mode]=\"sidenavProperties.mode\">\n        <div\n            #drawerContainer\n            class=\"drawer-container\"></div>\n    </mat-drawer>\n</mat-drawer-container>\n"]}
|
|
@@ -10,7 +10,6 @@ import { CommandsService } from '../services/commands.service';
|
|
|
10
10
|
import { ComponentService } from './custom-components/shared/services/component/component.service';
|
|
11
11
|
import { CustomContentService } from './custom-components/shared/services/custom-content/custom-content.service';
|
|
12
12
|
import { EditorComponent } from './editor.component';
|
|
13
|
-
import { ElementToolbarComponent } from './custom-components/external-element/element-toolbar/element-toolbar.component';
|
|
14
13
|
import { EXTERNAL_ELEMENT_SERVICE, EXTERNAL_ELEMENT_SIDENAV } from './custom-components/external-element/external-elements.const';
|
|
15
14
|
import { ExternalElementService } from './custom-components/external-element/external-element.service';
|
|
16
15
|
import { ExternalSidenavModel } from './custom-components/external-element/models/external-sidenav.model';
|
|
@@ -37,7 +36,6 @@ export class EditorModule {
|
|
|
37
36
|
}
|
|
38
37
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: EditorModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
39
38
|
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.2.1", ngImport: i0, type: EditorModule, declarations: [EditorComponent,
|
|
40
|
-
ElementToolbarComponent,
|
|
41
39
|
NoderEdgeComponent,
|
|
42
40
|
NoderImageComponent,
|
|
43
41
|
NoderTabComponent,
|
|
@@ -60,7 +58,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImpor
|
|
|
60
58
|
args: [{
|
|
61
59
|
declarations: [
|
|
62
60
|
EditorComponent,
|
|
63
|
-
ElementToolbarComponent,
|
|
64
61
|
NoderEdgeComponent,
|
|
65
62
|
NoderImageComponent,
|
|
66
63
|
NoderTabComponent,
|
|
@@ -82,4 +79,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImpor
|
|
|
82
79
|
exports: [EditorComponent]
|
|
83
80
|
}]
|
|
84
81
|
}] });
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdG9yLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1ub2Rlci9zcmMvbGliLytzaGFyZWQvZWRpdG9yL2VkaXRvci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBdUIsUUFBUSxFQUFRLE1BQU0sZUFBZSxDQUFDO0FBQ3BFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRXJELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUMvRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpRUFBaUUsQ0FBQztBQUNuRyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwyRUFBMkUsQ0FBQztBQUNqSCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDckQsT0FBTyxFQUFFLHdCQUF3QixFQUFFLHdCQUF3QixFQUFFLE1BQU0sOERBQThELENBQUM7QUFDbEksT0FBTyxFQUE0QixzQkFBc0IsRUFBRSxNQUFNLCtEQUErRCxDQUFDO0FBQ2pJLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLG9FQUFvRSxDQUFDO0FBQzFHLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxzREFBc0QsQ0FBQztBQUN2RixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxzREFBc0QsQ0FBQztBQUMzRixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUMxRSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSwyREFBMkQsQ0FBQztBQUNwRyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxzREFBc0QsQ0FBQztBQUMzRixPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sNkRBQTZELENBQUM7QUFDN0YsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDakUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0scURBQXFELENBQUM7QUFDdkYsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sK0RBQStELENBQUM7O0FBOEIxRyxNQUFNLE9BQU8sWUFBWTtJQUNyQixNQUFNLENBQUMsT0FBTyxDQUFDLE9BQXVCO1FBQ2xDLE9BQU87WUFDSCxRQUFRLEVBQUUsWUFBWTtZQUN0QixTQUFTLEVBQUU7Z0JBQ1AsRUFBRSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsUUFBUSxFQUFFLElBQUksb0JBQW9CLENBQUMsT0FBTyxFQUFFLE9BQU8sQ0FBQyxFQUFFO2dCQUMzRixFQUFFLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLGNBQWMsSUFBSSxzQkFBc0IsRUFBRTthQUNyRztTQUNKLENBQUM7SUFDTixDQUFDOzhHQVRRLFlBQVk7K0dBQVosWUFBWSxpQkFyQmpCLGVBQWU7WUFDZixrQkFBa0I7WUFDbEIsbUJBQW1CO1lBQ25CLGlCQUFpQjtZQUNqQix1QkFBdUI7WUFDdkIsbUJBQW1CO1lBQ25CLGdCQUFnQjtZQUNoQix5QkFBeUIsYUFFbkIsWUFBWSxFQUFFLGVBQWUsRUFBRSxlQUFlLEVBQUUsYUFBYSxFQUFFLGdCQUFnQixFQUFFLGdCQUFnQixFQUFFLG1CQUFtQixhQVV0SCxlQUFlOytHQUVoQixZQUFZLGFBWFY7WUFDUCxnQkFBZ0I7WUFDaEIsb0JBQW9CO1lBQ3BCLGVBQWU7WUFDZixjQUFjO1lBQ2QsZ0JBQWdCO1lBQ2hCLHNCQUFzQjtZQUN0QixlQUFlO1NBQ2xCLFlBVFMsWUFBWSxFQUFFLGVBQWUsRUFBRSxlQUFlLEVBQUUsYUFBYSxFQUFFLGdCQUFnQixFQUFFLGdCQUFnQixFQUFFLG1CQUFtQjs7MkZBWXZILFlBQVk7a0JBdkJ4QixRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRTt3QkFDVixlQUFlO3dCQUNmLGtCQUFrQjt3QkFDbEIsbUJBQW1CO3dCQUNuQixpQkFBaUI7d0JBQ2pCLHVCQUF1Qjt3QkFDdkIsbUJBQW1CO3dCQUNuQixnQkFBZ0I7d0JBQ2hCLHlCQUF5QjtxQkFDNUI7b0JBQ0QsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLGVBQWUsRUFBRSxlQUFlLEVBQUUsYUFBYSxFQUFFLGdCQUFnQixFQUFFLGdCQUFnQixFQUFFLG1CQUFtQixDQUFDO29CQUNqSSxTQUFTLEVBQUU7d0JBQ1AsZ0JBQWdCO3dCQUNoQixvQkFBb0I7d0JBQ3BCLGVBQWU7d0JBQ2YsY0FBYzt3QkFDZCxnQkFBZ0I7d0JBQ2hCLHNCQUFzQjt3QkFDdEIsZUFBZTtxQkFDbEI7b0JBQ0QsT0FBTyxFQUFFLENBQUMsZUFBZSxDQUFDO2lCQUM3QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTWF0RGlhbG9nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcbmltcG9ydCB7IE1hdFNpZGVuYXZNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9zaWRlbmF2JztcbmltcG9ydCB7IE1hdFRvb2x0aXBNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90b29sdGlwJztcbmltcG9ydCB7IE1vZHVsZVdpdGhQcm92aWRlcnMsIE5nTW9kdWxlLCBUeXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5pbXBvcnQgeyBDb21tYW5kc1NlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9jb21tYW5kcy5zZXJ2aWNlJztcbmltcG9ydCB7IENvbXBvbmVudFNlcnZpY2UgfSBmcm9tICcuL2N1c3RvbS1jb21wb25lbnRzL3NoYXJlZC9zZXJ2aWNlcy9jb21wb25lbnQvY29tcG9uZW50LnNlcnZpY2UnO1xuaW1wb3J0IHsgQ3VzdG9tQ29udGVudFNlcnZpY2UgfSBmcm9tICcuL2N1c3RvbS1jb21wb25lbnRzL3NoYXJlZC9zZXJ2aWNlcy9jdXN0b20tY29udGVudC9jdXN0b20tY29udGVudC5zZXJ2aWNlJztcbmltcG9ydCB7IEVkaXRvckNvbXBvbmVudCB9IGZyb20gJy4vZWRpdG9yLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBFWFRFUk5BTF9FTEVNRU5UX1NFUlZJQ0UsIEVYVEVSTkFMX0VMRU1FTlRfU0lERU5BViB9IGZyb20gJy4vY3VzdG9tLWNvbXBvbmVudHMvZXh0ZXJuYWwtZWxlbWVudC9leHRlcm5hbC1lbGVtZW50cy5jb25zdCc7XG5pbXBvcnQgeyBFeHRlcm5hbEVsZW1lbnRJbnRlcmZhY2UsIEV4dGVybmFsRWxlbWVudFNlcnZpY2UgfSBmcm9tICcuL2N1c3RvbS1jb21wb25lbnRzL2V4dGVybmFsLWVsZW1lbnQvZXh0ZXJuYWwtZWxlbWVudC5zZXJ2aWNlJztcbmltcG9ydCB7IEV4dGVybmFsU2lkZW5hdk1vZGVsIH0gZnJvbSAnLi9jdXN0b20tY29tcG9uZW50cy9leHRlcm5hbC1lbGVtZW50L21vZGVscy9leHRlcm5hbC1zaWRlbmF2Lm1vZGVsJztcbmltcG9ydCB7IEltYWdlQXBpU2VydmljZSB9IGZyb20gJy4vY3VzdG9tLWNvbXBvbmVudHMvaW1hZ2Uvc2VydmljZXMvaW1hZ2UtYXBpLnNlcnZpY2UnO1xuaW1wb3J0IHsgTm9kZXJFZGdlQ29tcG9uZW50IH0gZnJvbSAnLi9jb3JlL2NvbXBvbmVudHMvZWRnZXMvZWRnZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgTm9kZXJJbWFnZUNvbXBvbmVudCB9IGZyb20gJy4vY3VzdG9tLWNvbXBvbmVudHMvaW1hZ2UvY29tcG9uZW50cy9pbWFnZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgTm9kZXJUYWJDb21wb25lbnQgfSBmcm9tICcuL2N1c3RvbS1jb21wb25lbnRzL3RhYi90YWIuY29tcG9uZW50JztcbmltcG9ydCB7IE5vZGVyVGFibGVDZWxsQ29tcG9uZW50IH0gZnJvbSAnLi9jdXN0b20tY29tcG9uZW50cy90YWJsZS9jb21wb25lbnRzL3RhYmxlLWNlbGwuY29tcG9uZW50JztcbmltcG9ydCB7IE5vZGVyVGFibGVDb21wb25lbnQgfSBmcm9tICcuL2N1c3RvbS1jb21wb25lbnRzL3RhYmxlL2NvbXBvbmVudHMvdGFibGUuY29tcG9uZW50JztcbmltcG9ydCB7IE92ZXJsYXlTZXJ2aWNlIH0gZnJvbSAnLi9jdXN0b20tY29tcG9uZW50cy9zaGFyZWQvc2VydmljZXMvb3ZlcmxheS9vdmVybGF5LnNlcnZpY2UnO1xuaW1wb3J0IHsgUmVndWxhdG9yU2VydmljZSB9IGZyb20gJy4vZXhlY3V0aW9uL3JlZ3VsYXRvci5zZXJ2aWNlJztcbmltcG9ydCB7IFJlc2l6ZXJDb21wb25lbnQgfSBmcm9tICcuL2N1c3RvbS1jb21wb25lbnRzL2ltYWdlL3Jlc2l6ZXIvcmVzaXplci5jb21wb25lbnQnO1xuaW1wb3J0IHsgVGFibGVPdmVybGF5TWVudUNvbXBvbmVudCB9IGZyb20gJy4vY3VzdG9tLWNvbXBvbmVudHMvdGFibGUvb3ZlcmxheS1tZW51L292ZXJsYXktbWVudS5jb21wb25lbnQnO1xuXG5leHBvcnQgaW50ZXJmYWNlIElOb2Rlck9wdGlvbnMge1xuICAgIHNpZGVuYXY/OiBQYXJ0aWFsPEV4dGVybmFsU2lkZW5hdk1vZGVsPjtcbiAgICBlbGVtZW50U2VydmljZTogVHlwZTxFeHRlcm5hbEVsZW1lbnRJbnRlcmZhY2U+O1xufVxuXG5ATmdNb2R1bGUoe1xuICAgIGRlY2xhcmF0aW9uczogW1xuICAgICAgICBFZGl0b3JDb21wb25lbnQsXG4gICAgICAgIE5vZGVyRWRnZUNvbXBvbmVudCxcbiAgICAgICAgTm9kZXJJbWFnZUNvbXBvbmVudCxcbiAgICAgICAgTm9kZXJUYWJDb21wb25lbnQsXG4gICAgICAgIE5vZGVyVGFibGVDZWxsQ29tcG9uZW50LFxuICAgICAgICBOb2RlclRhYmxlQ29tcG9uZW50LFxuICAgICAgICBSZXNpemVyQ29tcG9uZW50LFxuICAgICAgICBUYWJsZU92ZXJsYXlNZW51Q29tcG9uZW50XG4gICAgXSxcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBNYXRCdXR0b25Nb2R1bGUsIE1hdERpYWxvZ01vZHVsZSwgTWF0SWNvbk1vZHVsZSwgTWF0U2lkZW5hdk1vZHVsZSwgTWF0VG9vbHRpcE1vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZV0sXG4gICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIENvbXBvbmVudFNlcnZpY2UsXG4gICAgICAgIEN1c3RvbUNvbnRlbnRTZXJ2aWNlLFxuICAgICAgICBJbWFnZUFwaVNlcnZpY2UsXG4gICAgICAgIE92ZXJsYXlTZXJ2aWNlLFxuICAgICAgICBSZWd1bGF0b3JTZXJ2aWNlLFxuICAgICAgICBFeHRlcm5hbEVsZW1lbnRTZXJ2aWNlLFxuICAgICAgICBDb21tYW5kc1NlcnZpY2VcbiAgICBdLFxuICAgIGV4cG9ydHM6IFtFZGl0b3JDb21wb25lbnRdXG59KVxuZXhwb3J0IGNsYXNzIEVkaXRvck1vZHVsZSB7XG4gICAgc3RhdGljIGZvclJvb3Qob3B0aW9ucz86IElOb2Rlck9wdGlvbnMpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPEVkaXRvck1vZHVsZT4ge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgbmdNb2R1bGU6IEVkaXRvck1vZHVsZSxcbiAgICAgICAgICAgIHByb3ZpZGVyczogW1xuICAgICAgICAgICAgICAgIHsgcHJvdmlkZTogRVhURVJOQUxfRUxFTUVOVF9TSURFTkFWLCB1c2VWYWx1ZTogbmV3IEV4dGVybmFsU2lkZW5hdk1vZGVsKG9wdGlvbnM/LnNpZGVuYXYpIH0sXG4gICAgICAgICAgICAgICAgeyBwcm92aWRlOiBFWFRFUk5BTF9FTEVNRU5UX1NFUlZJQ0UsIHVzZUNsYXNzOiBvcHRpb25zPy5lbGVtZW50U2VydmljZSA/PyBFeHRlcm5hbEVsZW1lbnRTZXJ2aWNlIH1cbiAgICAgICAgICAgIF1cbiAgICAgICAgfTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -8,4 +8,4 @@ export class GeneralPropertiesModel {
|
|
|
8
8
|
Object.assign(this, fields);
|
|
9
9
|
}
|
|
10
10
|
}
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJhbC1wcm9wZXJ0aWVzLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW5vZGVyL3NyYy9saWIvK3NoYXJlZC9lZGl0b3IvZXhlY3V0aW9uL21vZGVscy9nZW5lcmFsLXByb3BlcnRpZXMubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFHdEUsTUFBTSxPQUFPLHNCQUFzQjtJQU0vQixZQUFZLE1BQXdDO1FBQ2hELElBQUksQ0FBQyxNQUFNLEVBQUU7WUFDVCxPQUFPO1NBQ1Y7UUFFRCxNQUFNLENBQUMsZUFBZSxLQUFLLGlCQUFpQixDQUFDO1FBRTdDLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ2hDLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERFRkFVTFRfVEFCX1dJRFRIIH0gZnJvbSAnLi4vLi4vY29yZS9jb25zdGFudHMvZWRpdG9yLmNvbnN0JztcbmltcG9ydCB7IE51bWJlcmluZ01vZGVsIH0gZnJvbSAnLi4vLi4vLi4vLi4vbW9kZWxzL2dlbmVyYXRlZC9udW1iZXJpbmcubW9kZWwnO1xuXG5leHBvcnQgY2xhc3MgR2VuZXJhbFByb3BlcnRpZXNNb2RlbCB7XG4gICAgZGVmYXVsdFRhYldpZHRoOiBudW1iZXI7XG4gICAgbnVtYmVyaW5nczogTnVtYmVyaW5nTW9kZWxbXTtcbiAgICBtYXhFZGdlSGVpZ2h0OiBudW1iZXI7XG4gICAgc2NhbGluZ1JhdGlvOiBudW1iZXI7XG5cbiAgICBjb25zdHJ1Y3RvcihmaWVsZHM/OiBQYXJ0aWFsPEdlbmVyYWxQcm9wZXJ0aWVzTW9kZWw+KSB7XG4gICAgICAgIGlmICghZmllbGRzKSB7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICBmaWVsZHMuZGVmYXVsdFRhYldpZHRoID8/PSBERUZBVUxUX1RBQl9XSURUSDtcblxuICAgICAgICBPYmplY3QuYXNzaWduKHRoaXMsIGZpZWxkcyk7XG4gICAgfVxufVxuIl19
|
|
@@ -7,7 +7,9 @@ import { EdgeSessionSourceModel } from './models/edge-session-source.model';
|
|
|
7
7
|
import { EditSession } from '../core/edit.session';
|
|
8
8
|
import { GeneralPropertiesModel } from './models/general-properties.model';
|
|
9
9
|
import { MainSessionSourceModel } from './models/main-session-source.model';
|
|
10
|
+
import { MarginModel } from '../core/models/margin.model';
|
|
10
11
|
import { Renderer } from '../core/renderer';
|
|
12
|
+
import { ScalingHelper } from '../../helpers/scaling.helper';
|
|
11
13
|
import { SessionModel } from './models/session.model';
|
|
12
14
|
import { TargetType } from '../operations/enums/target-type.enum';
|
|
13
15
|
import { VirtualRenderer } from '../core/virtual.renderer';
|
|
@@ -22,14 +24,22 @@ export class RegulatorService {
|
|
|
22
24
|
this.sessionIdIncrement = 0;
|
|
23
25
|
this.edgeEditingPage = null;
|
|
24
26
|
}
|
|
25
|
-
addMainSession(model,
|
|
27
|
+
addMainSession(model, pageWidth, scalingRatio, container) {
|
|
26
28
|
const currentSessionId = ++this.sessionIdIncrement;
|
|
27
|
-
const document = new Document(model,
|
|
29
|
+
const document = new Document(model, new MarginModel({
|
|
30
|
+
left: ScalingHelper.scale(model.marginLeft, scalingRatio),
|
|
31
|
+
right: ScalingHelper.scale(model.marginRight, scalingRatio),
|
|
32
|
+
top: model.marginTop,
|
|
33
|
+
bottom: model.marginBottom,
|
|
34
|
+
header: model.marginHeader,
|
|
35
|
+
footer: model.marginFooter
|
|
36
|
+
}), DocumentInfo.pagesSpace, pageWidth, model.pageHeight);
|
|
28
37
|
const renderer = new VirtualRenderer(container.nativeElement, this.editorService);
|
|
29
38
|
const session = new EditSession(document, currentSessionId, this.customContentService, model, this.selection, new GeneralPropertiesModel({
|
|
30
39
|
numberings: model.numberings,
|
|
31
|
-
defaultTabWidth: model.defaultTabWidth,
|
|
32
|
-
maxEdgeHeight: model.pageHeight * DEFAULT_EDGE_MAX_HEIGHT_MULTIPLIER
|
|
40
|
+
defaultTabWidth: ScalingHelper.scale(model.defaultTabWidth, scalingRatio),
|
|
41
|
+
maxEdgeHeight: model.pageHeight * DEFAULT_EDGE_MAX_HEIGHT_MULTIPLIER,
|
|
42
|
+
scalingRatio
|
|
33
43
|
}));
|
|
34
44
|
renderer.setSession(session);
|
|
35
45
|
renderer.scrollTo(session.scrollTop);
|
|
@@ -190,4 +200,4 @@ export class RegulatorService {
|
|
|
190
200
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: RegulatorService, decorators: [{
|
|
191
201
|
type: Injectable
|
|
192
202
|
}], ctorParameters: () => [{ type: i1.CustomContentService }, { type: i2.EditorService }] });
|
|
193
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"regulator.service.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-noder/src/lib/+shared/editor/execution/regulator.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, Injectable } from '@angular/core';\n\nimport { CellSessionSourceModel } from './models/cell-session-source.model';\nimport { CustomContentService } from '../custom-components/shared/services/custom-content/custom-content.service';\nimport { DEFAULT_EDGE_MAX_HEIGHT_MULTIPLIER } from '../core/constants/editor.const';\nimport { Document } from '../core/document';\nimport { DocumentInfo } from '../core/constants/document-info.const';\nimport { DocxModel } from '../../../models/generated/docx.model';\nimport { EdgeSessionSourceModel } from './models/edge-session-source.model';\nimport { EdgeType } from '../core/components/edges/edge-type.enum';\nimport { EditorService } from '../interaction/editor.service';\nimport { EditSession } from '../core/edit.session';\nimport { GeneralPropertiesModel } from './models/general-properties.model';\nimport { MainSessionSourceModel } from './models/main-session-source.model';\nimport { MarginModel } from '../core/models/margin.model';\nimport { NoderEdgeComponent } from '../core/components/edges/edge.component';\nimport { NoderTableCellComponent } from '../custom-components/table/components/table-cell.component';\nimport { PageType } from '../core/enums/page-type.enum';\nimport { Renderer } from '../core/renderer';\nimport { Selection } from '../positioning/selection';\nimport { SessionModel } from './models/session.model';\nimport { TableModel } from '../../../models/generated/table.model';\nimport { TargetModel } from '../../../models/generated/target.model';\nimport { TargetType } from '../operations/enums/target-type.enum';\nimport { VirtualRenderer } from '../core/virtual.renderer';\n\n@Injectable()\nexport class RegulatorService {\n    mainSession: SessionModel;\n\n    sessions: SessionModel[] = [];\n\n    currentSession: SessionModel;\n\n    selection: Selection;\n\n    sessionIdIncrement = 0;\n\n    edgeEditingPage: number | null = null;\n\n    constructor(private customContentService: CustomContentService, private editorService: EditorService) {}\n\n    addMainSession(model: DocxModel, margins: MarginModel, pageWidth: number, container: ElementRef<HTMLElement>): void {\n        const currentSessionId = ++this.sessionIdIncrement;\n        const document = new Document(model, margins, DocumentInfo.pagesSpace, pageWidth, model.pageHeight);\n        const renderer = new VirtualRenderer(container.nativeElement, this.editorService);\n        const session = new EditSession(\n            document,\n            currentSessionId,\n            this.customContentService,\n            model,\n            this.selection,\n            new GeneralPropertiesModel({\n                numberings: model.numberings,\n                defaultTabWidth: model.defaultTabWidth,\n                maxEdgeHeight: model.pageHeight * DEFAULT_EDGE_MAX_HEIGHT_MULTIPLIER\n            })\n        );\n        renderer.setSession(session);\n        renderer.scrollTo(session.scrollTop);\n        session.contentWidth = document.pageWidth - (document.pageMargin.left + document.pageMargin.right);\n        this.editorService.styles = session.stylesMap;\n        this.mainSession = new SessionModel(session, renderer, currentSessionId, null, new MainSessionSourceModel());\n        this.sessions.push(this.mainSession);\n        this.currentSession = this.mainSession;\n    }\n\n    addCellSession(\n        table: TableModel,\n        margins: MarginModel,\n        component: NoderTableCellComponent,\n        properties: GeneralPropertiesModel\n    ): SessionModel {\n        const currentSessionId = ++this.sessionIdIncrement;\n        const document = new Document(component.cell, margins, 0, component.width, 0);\n        const renderer = new Renderer(component.container.nativeElement, this.editorService);\n        const session = new EditSession(document, currentSessionId, this.customContentService, component.cell, this.selection, properties);\n        renderer.setSession(session);\n        const contentWidth = component.width - (document.pageMargin.left + document.pageMargin.right);\n        session.contentWidth = contentWidth === 0 ? 1 : contentWidth;\n        const source = new CellSessionSourceModel(table, component);\n        const newSession = new SessionModel(session, renderer, currentSessionId, component.parentSessionId, source);\n        this.sessions.push(newSession);\n        return newSession;\n    }\n\n    addEdgeSession(component: NoderEdgeComponent): SessionModel {\n        const currentSessionId = ++this.sessionIdIncrement;\n        const document = new Document(component.model, component.margins, 0, component.width, 0);\n        const renderer = new Renderer(component.container.nativeElement, this.editorService);\n        const session = new EditSession(\n            document,\n            currentSessionId,\n            this.customContentService,\n            component.model,\n            this.selection,\n            component.properties\n        );\n        renderer.setSession(session);\n        session.contentWidth = component.width - (document.pageMargin.left + document.pageMargin.right);\n        const source = new EdgeSessionSourceModel(component.model.pageType as PageType, component.type);\n        const newSession = new SessionModel(session, renderer, currentSessionId, component.parentSessionId, source);\n        this.sessions.push(newSession);\n        return newSession;\n    }\n\n    removeSession(sessionId: number) {\n        const index = this.sessions.findIndex(x => x.sessionId === sessionId);\n        this.sessions[index].session.destroy();\n        this.sessions[index].renderer.destroy();\n        this.sessions.splice(index, 1);\n    }\n\n    setMainSessionAsCurrent(): void {\n        if (this.mainSession.sessionId === this.currentSession.sessionId) {\n            return;\n        }\n        this.toggleEdgeEditMode();\n        this.setCurrentSession(this.mainSession);\n    }\n\n    setCustomSessionAsCurrent(sessionId: number): void {\n        if (sessionId === this.currentSession.sessionId) {\n            return;\n        }\n        this.toggleEdgeEditMode();\n        this.setCurrentSessionById(sessionId);\n    }\n\n    setEdgeSessionAsCurrent(sessionId: number, clickedPage: number) {\n        this.toggleEdgeEditMode(clickedPage);\n        if (sessionId === this.currentSession.sessionId) {\n            this.currentSession.source.edgeEditPage = clickedPage;\n            return;\n        }\n        this.setCurrentSessionById(sessionId);\n    }\n\n    setTargetedSessionAsCurrent(targets: TargetModel[]): void {\n        const targetedSession = this.getTargetedSession(targets);\n        if (targetedSession.sessionId === this.currentSession.sessionId) {\n            return;\n        }\n        const session = this.sessions.find(x => x.sessionId === targetedSession.sessionId);\n        const edgeEditPage = targets.length ? targets[targets.length - 1].edgeEditPage : null;\n        this.toggleEdgeEditMode(edgeEditPage);\n        this.setCurrentSession(session);\n    }\n\n    setCurrentSessionById(sessionId: number): void {\n        const index = this.sessions.findIndex(x => x.sessionId === sessionId);\n        this.setCurrentSession(this.sessions[index]);\n    }\n\n    setCurrentSession(session: SessionModel): void {\n        this.selection.clearSelection();\n        this.currentSession.renderer.hideCursor();\n        this.currentSession.renderer.updateSelection(this.selection.range);\n        this.currentSession = session;\n        this.currentSession.renderer.showCursor();\n        this.currentSession.source.edgeEditPage = this.edgeEditingPage;\n    }\n\n    getSession(sessionId: number): EditSession {\n        const session = this.sessions.find(x => x.sessionId === sessionId);\n        return session.session;\n    }\n\n    setSelection(selection: Selection): void {\n        this.selection = selection;\n    }\n\n    clearAllSessions(): void {\n        this.sessions.forEach(session => {\n            session.session.destroy();\n            session.renderer.destroy();\n        });\n        this.sessions = [];\n    }\n\n    getCurrentSessionTargets(): TargetModel[] {\n        return this.getTargets(this.currentSession);\n    }\n\n    getTargets(session: SessionModel): TargetModel[] {\n        const result: TargetModel[] = [];\n        let parentSession = this.sessions.find(x => x.sessionId === session.parentSessionId);\n        while (parentSession) {\n            const target = session.source.getTarget();\n            result.splice(0, 0, target);\n            session = parentSession;\n            parentSession = this.sessions.find(x => x.sessionId === parentSession.parentSessionId);\n        }\n        return result;\n    }\n\n    getEdgeTarget(sessionId: number): TargetModel | null {\n        let session = this.sessions.find(x => x.sessionId === sessionId);\n        let parentSession = this.sessions.find(x => x.sessionId === session.parentSessionId);\n        while (parentSession) {\n            const target = session.source.getTarget();\n            if (target.type === TargetType.Edge) {\n                return target;\n            }\n\n            session = parentSession;\n            parentSession = this.sessions.find(x => x.sessionId === parentSession.parentSessionId);\n        }\n\n        return null;\n    }\n\n    getTargetedSession(targets: TargetModel[]): EditSession {\n        let result = this.mainSession.session;\n        for (const target of targets) {\n            switch (target.type) {\n                case TargetType.Document:\n                    break;\n                case TargetType.TableCell: {\n                    const table = result.customComponents.tables.find(x => x.instance.content.insertIndex === target.tableCell.insertIndex);\n                    result = table.instance.getCellSession(target.tableCell.row, target.tableCell.column);\n                    break;\n                }\n                case TargetType.Edge: {\n                    const edge = result.customComponents.edges.getComponentByPageType(\n                        target.edgeData.pageType as PageType,\n                        target.edgeData.type as EdgeType\n                    );\n                    result = edge.instance.edgeSession.session;\n                    break;\n                }\n            }\n        }\n        return result;\n    }\n\n    toggleEdgeEditMode(clickedPage: number | null = null): void {\n        this.edgeEditingPage = clickedPage;\n        if (!this.mainSession.session.customComponents.edges) {\n            return;\n        }\n\n        this.mainSession.session.customComponents.edges.toggleEditMode(!!this.edgeEditingPage);\n        const mainRenderer = this.mainSession.renderer as VirtualRenderer;\n        mainRenderer.edgesLayer.update(mainRenderer.layerConfig);\n    }\n}\n"]}
|
|
203
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"regulator.service.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-noder/src/lib/+shared/editor/execution/regulator.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, Injectable } from '@angular/core';\n\nimport { CellSessionSourceModel } from './models/cell-session-source.model';\nimport { CustomContentService } from '../custom-components/shared/services/custom-content/custom-content.service';\nimport { DEFAULT_EDGE_MAX_HEIGHT_MULTIPLIER } from '../core/constants/editor.const';\nimport { Document } from '../core/document';\nimport { DocumentInfo } from '../core/constants/document-info.const';\nimport { DocxModel } from '../../../models/generated/docx.model';\nimport { EdgeSessionSourceModel } from './models/edge-session-source.model';\nimport { EdgeType } from '../core/components/edges/edge-type.enum';\nimport { EditSession } from '../core/edit.session';\nimport { EditorService } from '../interaction/editor.service';\nimport { GeneralPropertiesModel } from './models/general-properties.model';\nimport { MainSessionSourceModel } from './models/main-session-source.model';\nimport { MarginModel } from '../core/models/margin.model';\nimport { NoderEdgeComponent } from '../core/components/edges/edge.component';\nimport { NoderTableCellComponent } from '../custom-components/table/components/table-cell.component';\nimport { PageType } from '../core/enums/page-type.enum';\nimport { Renderer } from '../core/renderer';\nimport { ScalingHelper } from '../../helpers/scaling.helper';\nimport { Selection } from '../positioning/selection';\nimport { SessionModel } from './models/session.model';\nimport { TableModel } from '../../../models/generated/table.model';\nimport { TargetModel } from '../../../models/generated/target.model';\nimport { TargetType } from '../operations/enums/target-type.enum';\nimport { VirtualRenderer } from '../core/virtual.renderer';\n\n@Injectable()\nexport class RegulatorService {\n    mainSession: SessionModel;\n\n    sessions: SessionModel[] = [];\n\n    currentSession: SessionModel;\n\n    selection: Selection;\n\n    sessionIdIncrement = 0;\n\n    edgeEditingPage: number | null = null;\n\n    constructor(private customContentService: CustomContentService, private editorService: EditorService) {}\n\n    addMainSession(model: DocxModel, pageWidth: number, scalingRatio: number, container: ElementRef<HTMLElement>): void {\n        const currentSessionId = ++this.sessionIdIncrement;\n        const document = new Document(\n            model,\n            new MarginModel({\n                left: ScalingHelper.scale(model.marginLeft, scalingRatio),\n                right: ScalingHelper.scale(model.marginRight, scalingRatio),\n                top: model.marginTop,\n                bottom: model.marginBottom,\n                header: model.marginHeader,\n                footer: model.marginFooter\n            }),\n            DocumentInfo.pagesSpace,\n            pageWidth,\n            model.pageHeight\n        );\n        const renderer = new VirtualRenderer(container.nativeElement, this.editorService);\n        const session = new EditSession(\n            document,\n            currentSessionId,\n            this.customContentService,\n            model,\n            this.selection,\n            new GeneralPropertiesModel({\n                numberings: model.numberings,\n                defaultTabWidth: ScalingHelper.scale(model.defaultTabWidth, scalingRatio),\n                maxEdgeHeight: model.pageHeight * DEFAULT_EDGE_MAX_HEIGHT_MULTIPLIER,\n                scalingRatio\n            })\n        );\n        renderer.setSession(session);\n        renderer.scrollTo(session.scrollTop);\n        session.contentWidth = document.pageWidth - (document.pageMargin.left + document.pageMargin.right);\n        this.editorService.styles = session.stylesMap;\n        this.mainSession = new SessionModel(session, renderer, currentSessionId, null, new MainSessionSourceModel());\n        this.sessions.push(this.mainSession);\n        this.currentSession = this.mainSession;\n    }\n\n    addCellSession(\n        table: TableModel,\n        margins: MarginModel,\n        component: NoderTableCellComponent,\n        properties: GeneralPropertiesModel\n    ): SessionModel {\n        const currentSessionId = ++this.sessionIdIncrement;\n        const document = new Document(component.cell, margins, 0, component.width, 0);\n        const renderer = new Renderer(component.container.nativeElement, this.editorService);\n        const session = new EditSession(document, currentSessionId, this.customContentService, component.cell, this.selection, properties);\n        renderer.setSession(session);\n        const contentWidth = component.width - (document.pageMargin.left + document.pageMargin.right);\n        session.contentWidth = contentWidth === 0 ? 1 : contentWidth;\n        const source = new CellSessionSourceModel(table, component);\n        const newSession = new SessionModel(session, renderer, currentSessionId, component.parentSessionId, source);\n        this.sessions.push(newSession);\n        return newSession;\n    }\n\n    addEdgeSession(component: NoderEdgeComponent): SessionModel {\n        const currentSessionId = ++this.sessionIdIncrement;\n        const document = new Document(component.model, component.margins, 0, component.width, 0);\n        const renderer = new Renderer(component.container.nativeElement, this.editorService);\n        const session = new EditSession(\n            document,\n            currentSessionId,\n            this.customContentService,\n            component.model,\n            this.selection,\n            component.properties\n        );\n        renderer.setSession(session);\n        session.contentWidth = component.width - (document.pageMargin.left + document.pageMargin.right);\n        const source = new EdgeSessionSourceModel(component.model.pageType as PageType, component.type);\n        const newSession = new SessionModel(session, renderer, currentSessionId, component.parentSessionId, source);\n        this.sessions.push(newSession);\n        return newSession;\n    }\n\n    removeSession(sessionId: number) {\n        const index = this.sessions.findIndex(x => x.sessionId === sessionId);\n        this.sessions[index].session.destroy();\n        this.sessions[index].renderer.destroy();\n        this.sessions.splice(index, 1);\n    }\n\n    setMainSessionAsCurrent(): void {\n        if (this.mainSession.sessionId === this.currentSession.sessionId) {\n            return;\n        }\n        this.toggleEdgeEditMode();\n        this.setCurrentSession(this.mainSession);\n    }\n\n    setCustomSessionAsCurrent(sessionId: number): void {\n        if (sessionId === this.currentSession.sessionId) {\n            return;\n        }\n        this.toggleEdgeEditMode();\n        this.setCurrentSessionById(sessionId);\n    }\n\n    setEdgeSessionAsCurrent(sessionId: number, clickedPage: number) {\n        this.toggleEdgeEditMode(clickedPage);\n        if (sessionId === this.currentSession.sessionId) {\n            this.currentSession.source.edgeEditPage = clickedPage;\n            return;\n        }\n        this.setCurrentSessionById(sessionId);\n    }\n\n    setTargetedSessionAsCurrent(targets: TargetModel[]): void {\n        const targetedSession = this.getTargetedSession(targets);\n        if (targetedSession.sessionId === this.currentSession.sessionId) {\n            return;\n        }\n        const session = this.sessions.find(x => x.sessionId === targetedSession.sessionId);\n        const edgeEditPage = targets.length ? targets[targets.length - 1].edgeEditPage : null;\n        this.toggleEdgeEditMode(edgeEditPage);\n        this.setCurrentSession(session);\n    }\n\n    setCurrentSessionById(sessionId: number): void {\n        const index = this.sessions.findIndex(x => x.sessionId === sessionId);\n        this.setCurrentSession(this.sessions[index]);\n    }\n\n    setCurrentSession(session: SessionModel): void {\n        this.selection.clearSelection();\n        this.currentSession.renderer.hideCursor();\n        this.currentSession.renderer.updateSelection(this.selection.range);\n        this.currentSession = session;\n        this.currentSession.renderer.showCursor();\n        this.currentSession.source.edgeEditPage = this.edgeEditingPage;\n    }\n\n    getSession(sessionId: number): EditSession {\n        const session = this.sessions.find(x => x.sessionId === sessionId);\n        return session.session;\n    }\n\n    setSelection(selection: Selection): void {\n        this.selection = selection;\n    }\n\n    clearAllSessions(): void {\n        this.sessions.forEach(session => {\n            session.session.destroy();\n            session.renderer.destroy();\n        });\n        this.sessions = [];\n    }\n\n    getCurrentSessionTargets(): TargetModel[] {\n        return this.getTargets(this.currentSession);\n    }\n\n    getTargets(session: SessionModel): TargetModel[] {\n        const result: TargetModel[] = [];\n        let parentSession = this.sessions.find(x => x.sessionId === session.parentSessionId);\n        while (parentSession) {\n            const target = session.source.getTarget();\n            result.splice(0, 0, target);\n            session = parentSession;\n            parentSession = this.sessions.find(x => x.sessionId === parentSession.parentSessionId);\n        }\n        return result;\n    }\n\n    getEdgeTarget(sessionId: number): TargetModel | null {\n        let session = this.sessions.find(x => x.sessionId === sessionId);\n        let parentSession = this.sessions.find(x => x.sessionId === session.parentSessionId);\n        while (parentSession) {\n            const target = session.source.getTarget();\n            if (target.type === TargetType.Edge) {\n                return target;\n            }\n\n            session = parentSession;\n            parentSession = this.sessions.find(x => x.sessionId === parentSession.parentSessionId);\n        }\n\n        return null;\n    }\n\n    getTargetedSession(targets: TargetModel[]): EditSession {\n        let result = this.mainSession.session;\n        for (const target of targets) {\n            switch (target.type) {\n                case TargetType.Document:\n                    break;\n                case TargetType.TableCell: {\n                    const table = result.customComponents.tables.find(x => x.instance.content.insertIndex === target.tableCell.insertIndex);\n                    result = table.instance.getCellSession(target.tableCell.row, target.tableCell.column);\n                    break;\n                }\n                case TargetType.Edge: {\n                    const edge = result.customComponents.edges.getComponentByPageType(\n                        target.edgeData.pageType as PageType,\n                        target.edgeData.type as EdgeType\n                    );\n                    result = edge.instance.edgeSession.session;\n                    break;\n                }\n            }\n        }\n        return result;\n    }\n\n    toggleEdgeEditMode(clickedPage: number | null = null): void {\n        this.edgeEditingPage = clickedPage;\n        if (!this.mainSession.session.customComponents.edges) {\n            return;\n        }\n\n        this.mainSession.session.customComponents.edges.toggleEditMode(!!this.edgeEditingPage);\n        const mainRenderer = this.mainSession.renderer as VirtualRenderer;\n        mainRenderer.edgesLayer.update(mainRenderer.layerConfig);\n    }\n}\n"]}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
4
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
5
|
+
import { MatSelectModule } from '@angular/material/select';
|
|
6
|
+
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
7
|
+
import { DEFAULT_FILE_NAME } from '../constants/default-file-name.const';
|
|
8
|
+
import { ExternalElementService } from '../editor/custom-components/external-element/external-element.service';
|
|
9
|
+
import { Mode } from '../enums/mode.enum';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "@angular/common";
|
|
12
|
+
import * as i2 from "@angular/material/button";
|
|
13
|
+
import * as i3 from "@angular/material/icon";
|
|
14
|
+
import * as i4 from "@angular/material/tooltip";
|
|
15
|
+
export class EditorTitleComponent {
|
|
16
|
+
set rename$(value) {
|
|
17
|
+
value?.subscribe(() => this.setTitleActive(this.titleSpan.nativeElement));
|
|
18
|
+
}
|
|
19
|
+
constructor(cdr) {
|
|
20
|
+
this.cdr = cdr;
|
|
21
|
+
this.changeMode = new EventEmitter();
|
|
22
|
+
this.renameDocumentTitle = new EventEmitter();
|
|
23
|
+
this.selectedMode = Mode.Edit;
|
|
24
|
+
this.modeOptions = [
|
|
25
|
+
{
|
|
26
|
+
id: Mode.Edit,
|
|
27
|
+
text: 'Edit document',
|
|
28
|
+
icon: 'icon-edit-mode'
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
id: Mode.Fill,
|
|
32
|
+
text: 'Fill or print document',
|
|
33
|
+
icon: 'icon-fill-done'
|
|
34
|
+
},
|
|
35
|
+
{
|
|
36
|
+
id: Mode.View,
|
|
37
|
+
text: 'Read or print document',
|
|
38
|
+
icon: 'icon-view'
|
|
39
|
+
}
|
|
40
|
+
];
|
|
41
|
+
}
|
|
42
|
+
onRenameTitle(event) {
|
|
43
|
+
event.target.contentEditable = 'false';
|
|
44
|
+
this.title = event.target.textContent || DEFAULT_FILE_NAME;
|
|
45
|
+
event.target.innerText = this.title;
|
|
46
|
+
this.renameDocumentTitle.emit(this.title);
|
|
47
|
+
this.cdr.detectChanges();
|
|
48
|
+
}
|
|
49
|
+
onFocus(event) {
|
|
50
|
+
this.setTitleActive(event.target);
|
|
51
|
+
}
|
|
52
|
+
setTitleActive(element) {
|
|
53
|
+
if (element.contentEditable === 'true') {
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
element.contentEditable = 'true';
|
|
57
|
+
const range = document.createRange();
|
|
58
|
+
const sel = window.getSelection();
|
|
59
|
+
range.setStart(element.firstChild, element.textContent.length);
|
|
60
|
+
range.collapse(true);
|
|
61
|
+
sel.removeAllRanges();
|
|
62
|
+
sel.addRange(range);
|
|
63
|
+
element.focus();
|
|
64
|
+
}
|
|
65
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: EditorTitleComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
66
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: EditorTitleComponent, isStandalone: true, selector: "app-editor-title", inputs: { title: "title", rename$: "rename$" }, outputs: { changeMode: "changeMode", renameDocumentTitle: "renameDocumentTitle" }, providers: [ExternalElementService], viewQueries: [{ propertyName: "titleSpan", first: true, predicate: ["titleSpan"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"menu-header\">\n <div class=\"file-name\">\n <span\n #titleSpan\n class=\"title\"\n matTooltip=\"Double click to rename\"\n (blur)=\"onRenameTitle($event)\"\n (keydown.enter)=\"$event.target.blur()\"\n (dblclick)=\"onFocus($event)\">\n {{ title }}\n </span>\n </div>\n</div>\n<div class=\"editor-mode\">\n <button\n *ngFor=\"let mode of modeOptions\"\n mat-icon-button\n [class.selected-mode]=\"selectedMode === mode.id\"\n [matTooltip]=\"mode.text\"\n (click)=\"selectedMode = mode.id; changeMode.emit(mode.id)\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"{{ mode.icon }}\"></mat-icon>\n </button>\n</div>\n", styles: [":host{display:flex;position:relative;align-items:center;width:100%}.menu-header{width:35%;line-height:0;z-index:1}.file-name{display:block;margin:0 8px;overflow:hidden}.title{font-size:18px;font-weight:400;line-height:normal;outline:none;display:inline-block;white-space:nowrap;min-width:1px;overflow:hidden;max-width:100%;-webkit-user-select:none;user-select:none}.title:not(:focus){text-overflow:ellipsis}.editor-mode{display:flex;position:absolute;justify-content:center;width:100%}.mdc-icon-button{min-width:40px;min-height:40px;width:40px;height:40px;padding:8px}.mdc-icon-button:not(:first-child){margin-left:10px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i2.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "ngmodule", type: MatSelectModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
67
|
+
}
|
|
68
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: EditorTitleComponent, decorators: [{
|
|
69
|
+
type: Component,
|
|
70
|
+
args: [{ standalone: true, imports: [CommonModule, MatButtonModule, MatIconModule, MatTooltipModule, MatSelectModule], providers: [ExternalElementService], selector: 'app-editor-title', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"menu-header\">\n <div class=\"file-name\">\n <span\n #titleSpan\n class=\"title\"\n matTooltip=\"Double click to rename\"\n (blur)=\"onRenameTitle($event)\"\n (keydown.enter)=\"$event.target.blur()\"\n (dblclick)=\"onFocus($event)\">\n {{ title }}\n </span>\n </div>\n</div>\n<div class=\"editor-mode\">\n <button\n *ngFor=\"let mode of modeOptions\"\n mat-icon-button\n [class.selected-mode]=\"selectedMode === mode.id\"\n [matTooltip]=\"mode.text\"\n (click)=\"selectedMode = mode.id; changeMode.emit(mode.id)\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"{{ mode.icon }}\"></mat-icon>\n </button>\n</div>\n", styles: [":host{display:flex;position:relative;align-items:center;width:100%}.menu-header{width:35%;line-height:0;z-index:1}.file-name{display:block;margin:0 8px;overflow:hidden}.title{font-size:18px;font-weight:400;line-height:normal;outline:none;display:inline-block;white-space:nowrap;min-width:1px;overflow:hidden;max-width:100%;-webkit-user-select:none;user-select:none}.title:not(:focus){text-overflow:ellipsis}.editor-mode{display:flex;position:absolute;justify-content:center;width:100%}.mdc-icon-button{min-width:40px;min-height:40px;width:40px;height:40px;padding:8px}.mdc-icon-button:not(:first-child){margin-left:10px}\n"] }]
|
|
71
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { title: [{
|
|
72
|
+
type: Input
|
|
73
|
+
}], rename$: [{
|
|
74
|
+
type: Input
|
|
75
|
+
}], changeMode: [{
|
|
76
|
+
type: Output
|
|
77
|
+
}], renameDocumentTitle: [{
|
|
78
|
+
type: Output
|
|
79
|
+
}], titleSpan: [{
|
|
80
|
+
type: ViewChild,
|
|
81
|
+
args: ['titleSpan', { static: true }]
|
|
82
|
+
}] } });
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor-title.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-noder/src/lib/+shared/editor-title/editor-title.component.ts","../../../../../../projects/ngx-noder/src/lib/+shared/editor-title/editor-title.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatSelectModule } from '@angular/material/select';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { Observable } from 'rxjs';\n\nimport { DEFAULT_FILE_NAME } from '../constants/default-file-name.const';\nimport { ExternalElementService } from '../editor/custom-components/external-element/external-element.service';\nimport { Mode } from '../enums/mode.enum';\n\n@Component({\n    standalone: true,\n    imports: [CommonModule, MatButtonModule, MatIconModule, MatTooltipModule, MatSelectModule],\n    providers: [ExternalElementService],\n    selector: 'app-editor-title',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    templateUrl: './editor-title.component.html',\n    styleUrls: ['./editor-title.component.scss']\n})\nexport class EditorTitleComponent {\n    @Input() title: string;\n\n    @Input()\n    set rename$(value: Observable<void>) {\n        value?.subscribe(() => this.setTitleActive(this.titleSpan.nativeElement));\n    }\n\n    @Output() changeMode = new EventEmitter<Mode>();\n\n    @Output() renameDocumentTitle = new EventEmitter<string>();\n\n    @ViewChild('titleSpan', { static: true }) titleSpan: ElementRef<HTMLElement>;\n\n    selectedMode = Mode.Edit;\n\n    modeOptions = [\n        {\n            id: Mode.Edit,\n            text: 'Edit document',\n            icon: 'icon-edit-mode'\n        },\n        {\n            id: Mode.Fill,\n            text: 'Fill or print document',\n            icon: 'icon-fill-done'\n        },\n        {\n            id: Mode.View,\n            text: 'Read or print document',\n            icon: 'icon-view'\n        }\n    ];\n\n    constructor(private cdr: ChangeDetectorRef) {}\n\n    onRenameTitle(event: FocusEvent): void {\n        (event.target as HTMLElement).contentEditable = 'false';\n        this.title = (event.target as HTMLElement).textContent || DEFAULT_FILE_NAME;\n        (event.target as HTMLElement).innerText = this.title;\n        this.renameDocumentTitle.emit(this.title);\n        this.cdr.detectChanges();\n    }\n\n    onFocus(event: MouseEvent) {\n        this.setTitleActive(event.target as HTMLElement);\n    }\n\n    private setTitleActive(element: HTMLElement): void {\n        if (element.contentEditable === 'true') {\n            return;\n        }\n\n        element.contentEditable = 'true';\n        const range = document.createRange();\n        const sel = window.getSelection();\n        range.setStart(element.firstChild, element.textContent.length);\n        range.collapse(true);\n        sel.removeAllRanges();\n        sel.addRange(range);\n        element.focus();\n    }\n}\n","<div class=\"menu-header\">\n    <div class=\"file-name\">\n        <span\n            #titleSpan\n            class=\"title\"\n            matTooltip=\"Double click to rename\"\n            (blur)=\"onRenameTitle($event)\"\n            (keydown.enter)=\"$event.target.blur()\"\n            (dblclick)=\"onFocus($event)\">\n            {{ title }}\n        </span>\n    </div>\n</div>\n<div class=\"editor-mode\">\n    <button\n        *ngFor=\"let mode of modeOptions\"\n        mat-icon-button\n        [class.selected-mode]=\"selectedMode === mode.id\"\n        [matTooltip]=\"mode.text\"\n        (click)=\"selectedMode = mode.id; changeMode.emit(mode.id)\">\n        <mat-icon\n            fontSet=\"nc-icon\"\n            fontIcon=\"{{ mode.icon }}\"></mat-icon>\n    </button>\n</div>\n"]}
|
|
@@ -13,11 +13,11 @@ export class ColorPickerComponent {
|
|
|
13
13
|
this.colorChange.emit(color);
|
|
14
14
|
}
|
|
15
15
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: ColorPickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
16
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: ColorPickerComponent, selector: "app-color-picker", inputs: { color: "color", icon: "icon", isDisabled: "isDisabled", palette: "palette" }, outputs: { colorChange: "colorChange" }, ngImport: i0, template: "<button\n mat-button\n ngx-colors-trigger\n overlayClassName=\"color-picker-overlay\"\n [disabled]=\"isDisabled\"\n [(ngModel)]=\"color\"\n [palette]=\"palette\"\n [hideTextInput]=\"true\"\n [attachTo]=\"icon\"\n (input)=\"onChangeColor(color)\">\n <div\n class=\"color-text\"\n [ngStyle]=\"{ 'border-color': color ? color : 'transparent' }\">\n <mat-icon\n fontSet=\"nc-icon\"\n [fontIcon]=\"icon\"></mat-icon>\n </div>\n</button>\n", styles: ["button{margin:0 3px}.color-text{display:inline-flex;height:22px}.mdc-button{min-width:
|
|
16
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: ColorPickerComponent, selector: "app-color-picker", inputs: { color: "color", icon: "icon", isDisabled: "isDisabled", palette: "palette" }, outputs: { colorChange: "colorChange" }, ngImport: i0, template: "<button\n mat-button\n ngx-colors-trigger\n overlayClassName=\"color-picker-overlay\"\n [disabled]=\"isDisabled\"\n [(ngModel)]=\"color\"\n [palette]=\"palette\"\n [hideTextInput]=\"true\"\n [attachTo]=\"icon\"\n (input)=\"onChangeColor(color)\">\n <div\n class=\"color-text\"\n [ngStyle]=\"{ 'border-color': color ? color : 'transparent' }\">\n <mat-icon\n fontSet=\"nc-icon\"\n [fontIcon]=\"icon\"></mat-icon>\n </div>\n</button>\n", styles: ["button{margin:0 3px}.color-text{display:inline-flex;height:22px}.mdc-button{min-width:32px;height:32px;width:32px;padding:0}.mdc-button mat-icon{height:24px;width:24px}.mdc-button::ng-deep .mdc-button__label{display:flex}\n"], dependencies: [{ kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i5.NgxColorsTriggerDirective, selector: "[ngx-colors-trigger]", inputs: ["colorsAnimation", "palette", "format", "position", "hideTextInput", "hideColorPicker", "attachTo", "overlayClassName", "colorPickerControls", "acceptLabel", "cancelLabel"], outputs: ["change", "input", "slider", "close", "open"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
17
17
|
}
|
|
18
18
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: ColorPickerComponent, decorators: [{
|
|
19
19
|
type: Component,
|
|
20
|
-
args: [{ selector: 'app-color-picker', changeDetection: ChangeDetectionStrategy.OnPush, template: "<button\n mat-button\n ngx-colors-trigger\n overlayClassName=\"color-picker-overlay\"\n [disabled]=\"isDisabled\"\n [(ngModel)]=\"color\"\n [palette]=\"palette\"\n [hideTextInput]=\"true\"\n [attachTo]=\"icon\"\n (input)=\"onChangeColor(color)\">\n <div\n class=\"color-text\"\n [ngStyle]=\"{ 'border-color': color ? color : 'transparent' }\">\n <mat-icon\n fontSet=\"nc-icon\"\n [fontIcon]=\"icon\"></mat-icon>\n </div>\n</button>\n", styles: ["button{margin:0 3px}.color-text{display:inline-flex;height:22px}.mdc-button{min-width:
|
|
20
|
+
args: [{ selector: 'app-color-picker', changeDetection: ChangeDetectionStrategy.OnPush, template: "<button\n mat-button\n ngx-colors-trigger\n overlayClassName=\"color-picker-overlay\"\n [disabled]=\"isDisabled\"\n [(ngModel)]=\"color\"\n [palette]=\"palette\"\n [hideTextInput]=\"true\"\n [attachTo]=\"icon\"\n (input)=\"onChangeColor(color)\">\n <div\n class=\"color-text\"\n [ngStyle]=\"{ 'border-color': color ? color : 'transparent' }\">\n <mat-icon\n fontSet=\"nc-icon\"\n [fontIcon]=\"icon\"></mat-icon>\n </div>\n</button>\n", styles: ["button{margin:0 3px}.color-text{display:inline-flex;height:22px}.mdc-button{min-width:32px;height:32px;width:32px;padding:0}.mdc-button mat-icon{height:24px;width:24px}.mdc-button::ng-deep .mdc-button__label{display:flex}\n"] }]
|
|
21
21
|
}], propDecorators: { color: [{
|
|
22
22
|
type: Input
|
|
23
23
|
}], icon: [{
|