@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
|
@@ -1,115 +1,101 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
-
import { DEFAULT_FONT_SIZE } from '../editor/core/constants/editor.const';
|
|
3
|
-
import { NumberingTemplates } from './constants/numbering-templates.const';
|
|
4
|
-
import { ParagraphStyleModel } from '../../models/generated/paragraph-style.model';
|
|
5
|
-
import { TextStyleModel } from '../../models/generated/text-style.model';
|
|
6
|
-
import { ToolbarStylesHelper } from './helpers/toolbar-styles.helper';
|
|
7
2
|
import * as i0 from "@angular/core";
|
|
8
|
-
import * as i1 from "
|
|
9
|
-
import * as i2 from "
|
|
10
|
-
import * as i3 from "./
|
|
11
|
-
import * as i4 from "./font-size/font-size.component";
|
|
12
|
-
import * as i5 from "./font-style/font-style.component";
|
|
13
|
-
import * as i6 from "./format/format.component";
|
|
14
|
-
import * as i7 from "./numbering/numbering.component";
|
|
15
|
-
import * as i8 from "./print/print.component";
|
|
16
|
-
import * as i9 from "./undo-redo/undo-redo.component";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "./menu-dropdowns/menu-dropdowns.component";
|
|
5
|
+
import * as i3 from "./toolbar-actions/toolbar-actions.component";
|
|
17
6
|
export class EditorToolbarComponent {
|
|
18
|
-
|
|
19
|
-
this.
|
|
20
|
-
this.
|
|
21
|
-
this.
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
this.
|
|
28
|
-
this.
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
this.
|
|
32
|
-
this.
|
|
7
|
+
constructor() {
|
|
8
|
+
this.showActions = true;
|
|
9
|
+
this.openFileFromDisk = new EventEmitter();
|
|
10
|
+
this.addCustomElement = new EventEmitter();
|
|
11
|
+
this.saveAs = new EventEmitter();
|
|
12
|
+
this.print = new EventEmitter();
|
|
13
|
+
this.insertPageBreak = new EventEmitter();
|
|
14
|
+
this.createDocument = new EventEmitter();
|
|
15
|
+
this.insertImage = new EventEmitter();
|
|
16
|
+
this.rename = new EventEmitter();
|
|
17
|
+
this.delete = new EventEmitter();
|
|
18
|
+
this.openEditMenu = new EventEmitter();
|
|
19
|
+
this.redo = new EventEmitter();
|
|
20
|
+
this.undo = new EventEmitter();
|
|
21
|
+
this.cutSelected = new EventEmitter();
|
|
22
|
+
this.copySelected = new EventEmitter();
|
|
23
|
+
this.pasteClipboardData = new EventEmitter();
|
|
24
|
+
this.selectAll = new EventEmitter();
|
|
25
|
+
this.removeSelected = new EventEmitter();
|
|
26
|
+
this.insertLink = new EventEmitter();
|
|
27
|
+
this.createElement = new EventEmitter();
|
|
33
28
|
this.changeParagraphStyle = new EventEmitter();
|
|
29
|
+
this.changeTextStyle = new EventEmitter();
|
|
34
30
|
this.setNumberingTemplateType = new EventEmitter();
|
|
35
31
|
this.removeNumberings = new EventEmitter();
|
|
36
|
-
this.
|
|
37
|
-
this.undo = new EventEmitter();
|
|
38
|
-
this.print = new EventEmitter();
|
|
39
|
-
this.customIconService.register();
|
|
40
|
-
}
|
|
41
|
-
onApplyFontFamily(font) {
|
|
42
|
-
this.checkFontLoadedAndApplyStyle(new TextStyleModel({ fontFamily: font }));
|
|
43
|
-
}
|
|
44
|
-
onApplyFontSize(size) {
|
|
45
|
-
this.checkFontLoadedAndApplyStyle(new TextStyleModel({ fontSize: size }));
|
|
46
|
-
}
|
|
47
|
-
onApplyBold(bold) {
|
|
48
|
-
this.checkFontLoadedAndApplyStyle(new TextStyleModel({ bold }));
|
|
32
|
+
this.insertTable = new EventEmitter();
|
|
49
33
|
}
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
}
|
|
53
|
-
onApplyItalic(italic) {
|
|
54
|
-
this.checkFontLoadedAndApplyStyle(new TextStyleModel({ italic }));
|
|
55
|
-
}
|
|
56
|
-
onApplyFontColor(color) {
|
|
57
|
-
this.changeTextStyle.emit(new TextStyleModel({ fontColor: color }));
|
|
58
|
-
}
|
|
59
|
-
onApplyHighlightColor(color) {
|
|
60
|
-
this.changeTextStyle.emit(new TextStyleModel({ highlightColor: color }));
|
|
61
|
-
}
|
|
62
|
-
onApplyAlignment(alignment) {
|
|
63
|
-
this.changeParagraphStyle.emit(new ParagraphStyleModel({ alignment }));
|
|
64
|
-
}
|
|
65
|
-
onSetNumberingTemplateType(templateType) {
|
|
66
|
-
const templateLevels = NumberingTemplates.find(x => x.templateType === templateType).levels;
|
|
67
|
-
this.setNumberingTemplateType.emit(templateLevels);
|
|
68
|
-
}
|
|
69
|
-
onRemoveNumberings() {
|
|
70
|
-
this.removeNumberings.emit();
|
|
71
|
-
}
|
|
72
|
-
checkFontLoadedAndApplyStyle(style) {
|
|
73
|
-
const newStyles = { ...this.styles, ...style };
|
|
74
|
-
const italic = newStyles.italic ? 'italic ' : '';
|
|
75
|
-
const bold = newStyles.bold ? 'bold ' : '';
|
|
76
|
-
const fontStyles = `${italic}${bold}${newStyles.fontSize ?? DEFAULT_FONT_SIZE}pt ${newStyles.fontFamily}`;
|
|
77
|
-
if (document.fonts.check(fontStyles)) {
|
|
78
|
-
this.changeTextStyle.emit(style);
|
|
79
|
-
return;
|
|
80
|
-
}
|
|
81
|
-
document.fonts
|
|
82
|
-
.load(fontStyles)
|
|
83
|
-
.then(() => this.changeTextStyle.emit(style))
|
|
84
|
-
.catch(() => {
|
|
85
|
-
// continue regardless of error
|
|
86
|
-
});
|
|
87
|
-
}
|
|
88
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: EditorToolbarComponent, deps: [{ token: i1.CustomIconService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
89
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: EditorToolbarComponent, selector: "app-editor-toolbar", inputs: { isViewOnly: "isViewOnly", styles: "styles", historyInfo: "historyInfo" }, outputs: { changeTextStyle: "changeTextStyle", changeParagraphStyle: "changeParagraphStyle", setNumberingTemplateType: "setNumberingTemplateType", removeNumberings: "removeNumberings", redo: "redo", undo: "undo", print: "print" }, ngImport: i0, template: "<ng-container *ngIf=\"styles\">\n <app-undo-redo\n [canUndo]=\"canUndo\"\n [canRedo]=\"canRedo\"\n (undo)=\"undo.emit()\"\n (redo)=\"redo.emit()\"></app-undo-redo>\n <app-print (print)=\"print.emit()\"></app-print>\n <div class=\"separator\"></div>\n <app-font\n [isDisabled]=\"isViewOnly\"\n [styles]=\"styles\"\n (selectFont)=\"onApplyFontFamily($event)\"></app-font>\n <div class=\"separator\"></div>\n <app-font-size\n [isDisabled]=\"isViewOnly\"\n [fontSize]=\"styles.fontSize\"\n (selectFontSize)=\"onApplyFontSize($event)\"></app-font-size>\n <div class=\"separator\"></div>\n <app-font-style\n [isDisabled]=\"isViewOnly\"\n [bold]=\"styles.bold\"\n [italic]=\"styles.italic\"\n [underline]=\"styles.underline\"\n [fontColor]=\"styles.fontColor\"\n [highlightColor]=\"styles.highlightColor\"\n (selectFontColor)=\"onApplyFontColor($event)\"\n (toggleBold)=\"onApplyBold($event)\"\n (toggleItalic)=\"onApplyItalic($event)\"\n (toggleUnderline)=\"onApplyUnderline($event)\"\n (selectHighlightColor)=\"onApplyHighlightColor($event)\"></app-font-style>\n <div class=\"separator\"></div>\n <app-format\n [isDisabled]=\"isViewOnly\"\n [alignment]=\"styles.alignment\"\n (selectAlignment)=\"onApplyAlignment($event)\"></app-format>\n <div class=\"separator\"></div>\n <app-numbering\n [isDisabled]=\"isViewOnly\"\n [selectedNumberingType]=\"numberingType\"\n [selectedNumberingTemplate]=\"numberingTemplateType\"\n (selectNumberingTemplate)=\"onSetNumberingTemplateType($event)\"\n (removeNumberings)=\"onRemoveNumberings()\"></app-numbering>\n</ng-container>\n", styles: [":host ::ng-deep{display:flex;height:40px;justify-content:center;border-bottom:1px solid}:host ::ng-deep mat-button-toggle,:host ::ng-deep .mat-button-toggle-button{height:28px;width:28px;border-radius:4px}:host ::ng-deep mat-button-toggle mat-icon,:host ::ng-deep .mat-button-toggle-button mat-icon{font-size:24px;height:24px;width:24px;border-radius:4px}:host ::ng-deep mat-button-toggle .mat-button-toggle-label-content,:host ::ng-deep .mat-button-toggle-button .mat-button-toggle-label-content{padding:0 2px}.separator{border-left:1px solid;opacity:.1;height:100%;margin:0 8px}.mdc-button{width:28px;height:28px;padding:0}.mat-mdc-button>.mat-icon{margin-right:0}.do-action{padding-right:1px;justify-content:center;display:flex}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.FontComponent, selector: "app-font", inputs: ["isDisabled", "styles"], outputs: ["selectFont"] }, { kind: "component", type: i4.FontSizeComponent, selector: "app-font-size", inputs: ["isDisabled", "fontSize"], outputs: ["selectFontSize"] }, { kind: "component", type: i5.FontStyleComponent, selector: "app-font-style", inputs: ["isDisabled", "bold", "italic", "underline", "fontColor", "highlightColor"], outputs: ["toggleBold", "toggleItalic", "toggleUnderline", "selectFontColor", "selectHighlightColor"] }, { kind: "component", type: i6.FormatComponent, selector: "app-format", inputs: ["isDisabled", "alignment"], outputs: ["selectAlignment"] }, { kind: "component", type: i7.NumberingComponent, selector: "app-numbering", inputs: ["isDisabled", "selectedNumberingType", "selectedNumberingTemplate"], outputs: ["selectNumberingTemplate", "removeNumberings"] }, { kind: "component", type: i8.PrintComponent, selector: "app-print", outputs: ["print"] }, { kind: "component", type: i9.UndoRedoComponent, selector: "app-undo-redo", inputs: ["canUndo", "canRedo"], outputs: ["undo", "redo"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
34
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: EditorToolbarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
35
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: EditorToolbarComponent, selector: "app-editor-toolbar", inputs: { showActions: "showActions", isViewOnly: "isViewOnly", hasSelection: "hasSelection", clipboardData: "clipboardData", historyInfo: "historyInfo", styles: "styles" }, outputs: { openFileFromDisk: "openFileFromDisk", addCustomElement: "addCustomElement", saveAs: "saveAs", print: "print", insertPageBreak: "insertPageBreak", createDocument: "createDocument", insertImage: "insertImage", rename: "rename", delete: "delete", openEditMenu: "openEditMenu", redo: "redo", undo: "undo", cutSelected: "cutSelected", copySelected: "copySelected", pasteClipboardData: "pasteClipboardData", selectAll: "selectAll", removeSelected: "removeSelected", insertLink: "insertLink", createElement: "createElement", changeParagraphStyle: "changeParagraphStyle", changeTextStyle: "changeTextStyle", setNumberingTemplateType: "setNumberingTemplateType", removeNumberings: "removeNumberings", insertTable: "insertTable" }, ngImport: i0, template: "<app-menu-dropdowns\n [isViewOnly]=\"isViewOnly\"\n [hasSelection]=\"hasSelection\"\n [clipboardData]=\"clipboardData\"\n [historyInfo]=\"historyInfo\"\n [styles]=\"styles\"\n (openFileFromDisk)=\"openFileFromDisk.emit($event)\"\n (addCustomElement)=\"addCustomElement.emit($event)\"\n (saveAs)=\"saveAs.emit()\"\n (print)=\"print.emit()\"\n (insertPageBreak)=\"insertPageBreak.emit()\"\n (createDocument)=\"createDocument.emit()\"\n (insertImage)=\"insertImage.emit($event)\"\n (rename)=\"rename.emit()\"\n (delete)=\"delete.emit()\"\n (openEditMenu)=\"openEditMenu.emit()\"\n (redo)=\"redo.emit()\"\n (undo)=\"undo.emit()\"\n (cutSelected)=\"cutSelected.emit()\"\n (copySelected)=\"copySelected.emit()\"\n (pasteClipboardData)=\"pasteClipboardData.emit()\"\n (selectAll)=\"selectAll.emit()\"\n (removeSelected)=\"removeSelected.emit()\"\n (insertLink)=\"insertLink.emit()\"\n (createElement)=\"createElement.emit($event)\"\n (changeParagraphStyle)=\"changeParagraphStyle.emit($event)\"\n (changeTextStyle)=\"changeTextStyle.emit($event)\"\n (setNumberingTemplateType)=\"setNumberingTemplateType.emit($event)\"\n (removeNumberings)=\"removeNumberings.emit()\"\n (insertTable)=\"insertTable.emit($event)\" />\n<app-toolbar-actions\n *ngIf=\"styles && showActions\"\n [isViewOnly]=\"isViewOnly\"\n [historyInfo]=\"historyInfo\"\n [styles]=\"styles\"\n (print)=\"print.emit()\"\n (redo)=\"redo.emit()\"\n (undo)=\"undo.emit()\"\n (changeParagraphStyle)=\"changeParagraphStyle.emit($event)\"\n (changeTextStyle)=\"changeTextStyle.emit($event)\"\n (setNumberingTemplateType)=\"setNumberingTemplateType.emit($event)\"\n (removeNumberings)=\"removeNumberings.emit()\"\n (createElement)=\"createElement.emit($event)\" />\n", styles: [":host ::ng-deep{display:flex;position:relative;width:100%;height:32px}app-toolbar-actions{display:flex;position:absolute;align-items:center;justify-content:center;width:100%;height:100%}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MenuDropdownsComponent, selector: "app-menu-dropdowns", inputs: ["isViewOnly", "hasSelection", "clipboardData", "historyInfo", "styles"], outputs: ["openFileFromDisk", "addCustomElement", "saveAs", "print", "insertPageBreak", "createDocument", "insertImage", "rename", "delete", "openEditMenu", "redo", "undo", "cutSelected", "copySelected", "pasteClipboardData", "selectAll", "removeSelected", "insertLink", "createElement", "changeParagraphStyle", "changeTextStyle", "setNumberingTemplateType", "removeNumberings", "insertTable"] }, { kind: "component", type: i3.ToolbarActionsComponent, selector: "app-toolbar-actions", inputs: ["isViewOnly", "historyInfo", "styles"], outputs: ["print", "redo", "undo", "changeParagraphStyle", "changeTextStyle", "setNumberingTemplateType", "removeNumberings", "createElement"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
90
36
|
}
|
|
91
37
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: EditorToolbarComponent, decorators: [{
|
|
92
38
|
type: Component,
|
|
93
|
-
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'app-editor-toolbar', template: "<
|
|
94
|
-
}],
|
|
39
|
+
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'app-editor-toolbar', template: "<app-menu-dropdowns\n [isViewOnly]=\"isViewOnly\"\n [hasSelection]=\"hasSelection\"\n [clipboardData]=\"clipboardData\"\n [historyInfo]=\"historyInfo\"\n [styles]=\"styles\"\n (openFileFromDisk)=\"openFileFromDisk.emit($event)\"\n (addCustomElement)=\"addCustomElement.emit($event)\"\n (saveAs)=\"saveAs.emit()\"\n (print)=\"print.emit()\"\n (insertPageBreak)=\"insertPageBreak.emit()\"\n (createDocument)=\"createDocument.emit()\"\n (insertImage)=\"insertImage.emit($event)\"\n (rename)=\"rename.emit()\"\n (delete)=\"delete.emit()\"\n (openEditMenu)=\"openEditMenu.emit()\"\n (redo)=\"redo.emit()\"\n (undo)=\"undo.emit()\"\n (cutSelected)=\"cutSelected.emit()\"\n (copySelected)=\"copySelected.emit()\"\n (pasteClipboardData)=\"pasteClipboardData.emit()\"\n (selectAll)=\"selectAll.emit()\"\n (removeSelected)=\"removeSelected.emit()\"\n (insertLink)=\"insertLink.emit()\"\n (createElement)=\"createElement.emit($event)\"\n (changeParagraphStyle)=\"changeParagraphStyle.emit($event)\"\n (changeTextStyle)=\"changeTextStyle.emit($event)\"\n (setNumberingTemplateType)=\"setNumberingTemplateType.emit($event)\"\n (removeNumberings)=\"removeNumberings.emit()\"\n (insertTable)=\"insertTable.emit($event)\" />\n<app-toolbar-actions\n *ngIf=\"styles && showActions\"\n [isViewOnly]=\"isViewOnly\"\n [historyInfo]=\"historyInfo\"\n [styles]=\"styles\"\n (print)=\"print.emit()\"\n (redo)=\"redo.emit()\"\n (undo)=\"undo.emit()\"\n (changeParagraphStyle)=\"changeParagraphStyle.emit($event)\"\n (changeTextStyle)=\"changeTextStyle.emit($event)\"\n (setNumberingTemplateType)=\"setNumberingTemplateType.emit($event)\"\n (removeNumberings)=\"removeNumberings.emit()\"\n (createElement)=\"createElement.emit($event)\" />\n", styles: [":host ::ng-deep{display:flex;position:relative;width:100%;height:32px}app-toolbar-actions{display:flex;position:absolute;align-items:center;justify-content:center;width:100%;height:100%}\n"] }]
|
|
40
|
+
}], propDecorators: { showActions: [{
|
|
95
41
|
type: Input
|
|
96
|
-
}],
|
|
42
|
+
}], isViewOnly: [{
|
|
43
|
+
type: Input
|
|
44
|
+
}], hasSelection: [{
|
|
45
|
+
type: Input
|
|
46
|
+
}], clipboardData: [{
|
|
97
47
|
type: Input
|
|
98
48
|
}], historyInfo: [{
|
|
99
49
|
type: Input
|
|
100
|
-
}],
|
|
50
|
+
}], styles: [{
|
|
51
|
+
type: Input
|
|
52
|
+
}], openFileFromDisk: [{
|
|
101
53
|
type: Output
|
|
102
|
-
}],
|
|
54
|
+
}], addCustomElement: [{
|
|
103
55
|
type: Output
|
|
104
|
-
}],
|
|
56
|
+
}], saveAs: [{
|
|
105
57
|
type: Output
|
|
106
|
-
}],
|
|
58
|
+
}], print: [{
|
|
59
|
+
type: Output
|
|
60
|
+
}], insertPageBreak: [{
|
|
61
|
+
type: Output
|
|
62
|
+
}], createDocument: [{
|
|
63
|
+
type: Output
|
|
64
|
+
}], insertImage: [{
|
|
65
|
+
type: Output
|
|
66
|
+
}], rename: [{
|
|
67
|
+
type: Output
|
|
68
|
+
}], delete: [{
|
|
69
|
+
type: Output
|
|
70
|
+
}], openEditMenu: [{
|
|
107
71
|
type: Output
|
|
108
72
|
}], redo: [{
|
|
109
73
|
type: Output
|
|
110
74
|
}], undo: [{
|
|
111
75
|
type: Output
|
|
112
|
-
}],
|
|
76
|
+
}], cutSelected: [{
|
|
77
|
+
type: Output
|
|
78
|
+
}], copySelected: [{
|
|
79
|
+
type: Output
|
|
80
|
+
}], pasteClipboardData: [{
|
|
81
|
+
type: Output
|
|
82
|
+
}], selectAll: [{
|
|
83
|
+
type: Output
|
|
84
|
+
}], removeSelected: [{
|
|
85
|
+
type: Output
|
|
86
|
+
}], insertLink: [{
|
|
87
|
+
type: Output
|
|
88
|
+
}], createElement: [{
|
|
89
|
+
type: Output
|
|
90
|
+
}], changeParagraphStyle: [{
|
|
91
|
+
type: Output
|
|
92
|
+
}], changeTextStyle: [{
|
|
93
|
+
type: Output
|
|
94
|
+
}], setNumberingTemplateType: [{
|
|
95
|
+
type: Output
|
|
96
|
+
}], removeNumberings: [{
|
|
97
|
+
type: Output
|
|
98
|
+
}], insertTable: [{
|
|
113
99
|
type: Output
|
|
114
100
|
}] } });
|
|
115
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor-toolbar.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-noder/src/lib/+shared/editor-toolbar/editor-toolbar.component.ts","../../../../../../projects/ngx-noder/src/lib/+shared/editor-toolbar/editor-toolbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';\n\nimport { Alignment } from './enums/alignment.enum';\nimport { CustomIconService } from '../services/custom-icon.service';\nimport { DEFAULT_FONT_SIZE } from '../editor/core/constants/editor.const';\nimport { IToolbarStyles } from '../editor/core/interfaces/toolbar-styles.interface';\nimport { NumberingLevelModel } from '../../models/generated/numbering-level.model';\nimport { NumberingTemplates } from './constants/numbering-templates.const';\nimport { NumberingTemplateType } from './enums/numbering-template-type.enum';\nimport { NumberingType } from './enums/numbering-type.enum';\nimport { OperationsHistoryInfoModel } from '../editor/operation-history/operations-history-info.model';\nimport { ParagraphStyleModel } from '../../models/generated/paragraph-style.model';\nimport { TextStyleModel } from '../../models/generated/text-style.model';\nimport { ToolbarStylesHelper } from './helpers/toolbar-styles.helper';\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    selector: 'app-editor-toolbar',\n    templateUrl: 'editor-toolbar.component.html',\n    styleUrls: ['editor-toolbar.component.scss']\n})\nexport class EditorToolbarComponent {\n    @Input() isViewOnly: boolean;\n\n    @Input()\n    set styles(value: IToolbarStyles) {\n        this._styles = value;\n        this.numberingType = ToolbarStylesHelper.getNumberingType(value.isBulletMarker);\n        this.numberingTemplateType = ToolbarStylesHelper.getNumberingTemplateType(value.numberingLevelsStyles);\n    }\n    get styles(): IToolbarStyles {\n        return this._styles;\n    }\n    private _styles: IToolbarStyles;\n\n    @Input()\n    set historyInfo(value: OperationsHistoryInfoModel) {\n        this.canUndo = value.step !== -1;\n        this.canRedo = value.step < value.lastStep;\n    }\n\n    canUndo: boolean;\n\n    canRedo: boolean;\n\n    numberingType: NumberingType | null;\n\n    numberingTemplateType: NumberingTemplateType | null;\n\n    @Output() changeTextStyle = new EventEmitter<TextStyleModel>();\n\n    @Output() changeParagraphStyle = new EventEmitter<ParagraphStyleModel>();\n\n    @Output() setNumberingTemplateType = new EventEmitter<NumberingLevelModel[]>();\n\n    @Output() removeNumberings = new EventEmitter<void>();\n\n    @Output() redo = new EventEmitter<void>();\n\n    @Output() undo = new EventEmitter<void>();\n\n    @Output() print = new EventEmitter<void>();\n\n    constructor(private customIconService: CustomIconService) {\n        this.customIconService.register();\n    }\n\n    onApplyFontFamily(font: string): void {\n        this.checkFontLoadedAndApplyStyle(new TextStyleModel({ fontFamily: font }));\n    }\n\n    onApplyFontSize(size: number): void {\n        this.checkFontLoadedAndApplyStyle(new TextStyleModel({ fontSize: size }));\n    }\n\n    onApplyBold(bold: boolean): void {\n        this.checkFontLoadedAndApplyStyle(new TextStyleModel({ bold }));\n    }\n\n    onApplyUnderline(underline: boolean): void {\n        this.changeTextStyle.emit(new TextStyleModel({ underline }));\n    }\n\n    onApplyItalic(italic: boolean): void {\n        this.checkFontLoadedAndApplyStyle(new TextStyleModel({ italic }));\n    }\n\n    onApplyFontColor(color: string): void {\n        this.changeTextStyle.emit(new TextStyleModel({ fontColor: color }));\n    }\n\n    onApplyHighlightColor(color: string): void {\n        this.changeTextStyle.emit(new TextStyleModel({ highlightColor: color }));\n    }\n\n    onApplyAlignment(alignment: Alignment): void {\n        this.changeParagraphStyle.emit(new ParagraphStyleModel({ alignment }));\n    }\n\n    onSetNumberingTemplateType(templateType: NumberingTemplateType): void {\n        const templateLevels = NumberingTemplates.find(x => x.templateType === templateType).levels;\n        this.setNumberingTemplateType.emit(templateLevels);\n    }\n\n    onRemoveNumberings(): void {\n        this.removeNumberings.emit();\n    }\n\n    private checkFontLoadedAndApplyStyle(style: TextStyleModel): void {\n        const newStyles = { ...this.styles, ...style };\n        const italic = newStyles.italic ? 'italic ' : '';\n        const bold = newStyles.bold ? 'bold ' : '';\n        const fontStyles = `${italic}${bold}${newStyles.fontSize ?? DEFAULT_FONT_SIZE}pt ${newStyles.fontFamily}`;\n\n        if (document.fonts.check(fontStyles)) {\n            this.changeTextStyle.emit(style);\n            return;\n        }\n\n        document.fonts\n            .load(fontStyles)\n            .then(() => this.changeTextStyle.emit(style))\n            .catch(() => {\n                // continue regardless of error\n            });\n    }\n}\n","<ng-container *ngIf=\"styles\">\n    <app-undo-redo\n        [canUndo]=\"canUndo\"\n        [canRedo]=\"canRedo\"\n        (undo)=\"undo.emit()\"\n        (redo)=\"redo.emit()\"></app-undo-redo>\n    <app-print (print)=\"print.emit()\"></app-print>\n    <div class=\"separator\"></div>\n    <app-font\n        [isDisabled]=\"isViewOnly\"\n        [styles]=\"styles\"\n        (selectFont)=\"onApplyFontFamily($event)\"></app-font>\n    <div class=\"separator\"></div>\n    <app-font-size\n        [isDisabled]=\"isViewOnly\"\n        [fontSize]=\"styles.fontSize\"\n        (selectFontSize)=\"onApplyFontSize($event)\"></app-font-size>\n    <div class=\"separator\"></div>\n    <app-font-style\n        [isDisabled]=\"isViewOnly\"\n        [bold]=\"styles.bold\"\n        [italic]=\"styles.italic\"\n        [underline]=\"styles.underline\"\n        [fontColor]=\"styles.fontColor\"\n        [highlightColor]=\"styles.highlightColor\"\n        (selectFontColor)=\"onApplyFontColor($event)\"\n        (toggleBold)=\"onApplyBold($event)\"\n        (toggleItalic)=\"onApplyItalic($event)\"\n        (toggleUnderline)=\"onApplyUnderline($event)\"\n        (selectHighlightColor)=\"onApplyHighlightColor($event)\"></app-font-style>\n    <div class=\"separator\"></div>\n    <app-format\n        [isDisabled]=\"isViewOnly\"\n        [alignment]=\"styles.alignment\"\n        (selectAlignment)=\"onApplyAlignment($event)\"></app-format>\n    <div class=\"separator\"></div>\n    <app-numbering\n        [isDisabled]=\"isViewOnly\"\n        [selectedNumberingType]=\"numberingType\"\n        [selectedNumberingTemplate]=\"numberingTemplateType\"\n        (selectNumberingTemplate)=\"onSetNumberingTemplateType($event)\"\n        (removeNumberings)=\"onRemoveNumberings()\"></app-numbering>\n</ng-container>\n"]}
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor-toolbar.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-noder/src/lib/+shared/editor-toolbar/editor-toolbar.component.ts","../../../../../../projects/ngx-noder/src/lib/+shared/editor-toolbar/editor-toolbar.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;;;;;AAehG,MAAM,OAAO,sBAAsB;IANnC;QAOa,gBAAW,GAAG,IAAI,CAAC;QAYlB,qBAAgB,GAAG,IAAI,YAAY,EAAO,CAAC;QAE3C,qBAAgB,GAAG,IAAI,YAAY,EAAoB,CAAC;QAExD,WAAM,GAAG,IAAI,YAAY,EAAE,CAAC;QAE5B,UAAK,GAAG,IAAI,YAAY,EAAQ,CAAC;QAEjC,oBAAe,GAAG,IAAI,YAAY,EAAO,CAAC;QAE1C,mBAAc,GAAG,IAAI,YAAY,EAAO,CAAC;QAEzC,gBAAW,GAAG,IAAI,YAAY,EAAO,CAAC;QAEtC,WAAM,GAAG,IAAI,YAAY,EAAE,CAAC;QAE5B,WAAM,GAAG,IAAI,YAAY,EAAU,CAAC;QAEpC,iBAAY,GAAG,IAAI,YAAY,EAAE,CAAC;QAElC,SAAI,GAAG,IAAI,YAAY,EAAQ,CAAC;QAEhC,SAAI,GAAG,IAAI,YAAY,EAAQ,CAAC;QAEhC,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QAEjC,iBAAY,GAAG,IAAI,YAAY,EAAE,CAAC;QAElC,uBAAkB,GAAG,IAAI,YAAY,EAAE,CAAC;QAExC,cAAS,GAAG,IAAI,YAAY,EAAE,CAAC;QAE/B,mBAAc,GAAG,IAAI,YAAY,EAAE,CAAC;QAEpC,eAAU,GAAG,IAAI,YAAY,EAAE,CAAC;QAEhC,kBAAa,GAAG,IAAI,YAAY,EAAoB,CAAC;QAErD,yBAAoB,GAAG,IAAI,YAAY,EAAuB,CAAC;QAE/D,oBAAe,GAAG,IAAI,YAAY,EAAkB,CAAC;QAErD,6BAAwB,GAAG,IAAI,YAAY,EAAyB,CAAC;QAErE,qBAAgB,GAAG,IAAI,YAAY,EAAQ,CAAC;QAE5C,gBAAW,GAAG,IAAI,YAAY,EAAqC,CAAC;KACjF;8GA5DY,sBAAsB;kGAAtB,sBAAsB,q8BCfnC,gzDA2CA;;2FD5Ba,sBAAsB;kBANlC,SAAS;sCACW,uBAAuB,CAAC,MAAM,YACrC,oBAAoB;8BAKrB,WAAW;sBAAnB,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBAEG,YAAY;sBAApB,KAAK;gBAEG,aAAa;sBAArB,KAAK;gBAEG,WAAW;sBAAnB,KAAK;gBAEG,MAAM;sBAAd,KAAK;gBAEI,gBAAgB;sBAAzB,MAAM;gBAEG,gBAAgB;sBAAzB,MAAM;gBAEG,MAAM;sBAAf,MAAM;gBAEG,KAAK;sBAAd,MAAM;gBAEG,eAAe;sBAAxB,MAAM;gBAEG,cAAc;sBAAvB,MAAM;gBAEG,WAAW;sBAApB,MAAM;gBAEG,MAAM;sBAAf,MAAM;gBAEG,MAAM;sBAAf,MAAM;gBAEG,YAAY;sBAArB,MAAM;gBAEG,IAAI;sBAAb,MAAM;gBAEG,IAAI;sBAAb,MAAM;gBAEG,WAAW;sBAApB,MAAM;gBAEG,YAAY;sBAArB,MAAM;gBAEG,kBAAkB;sBAA3B,MAAM;gBAEG,SAAS;sBAAlB,MAAM;gBAEG,cAAc;sBAAvB,MAAM;gBAEG,UAAU;sBAAnB,MAAM;gBAEG,aAAa;sBAAtB,MAAM;gBAEG,oBAAoB;sBAA7B,MAAM;gBAEG,eAAe;sBAAxB,MAAM;gBAEG,wBAAwB;sBAAjC,MAAM;gBAEG,gBAAgB;sBAAzB,MAAM;gBAEG,WAAW;sBAApB,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';\n\nimport { ElementDataModel } from '../editor/custom-components/external-element/models/element-data.model';\nimport { IToolbarStyles } from '../editor/core/interfaces/toolbar-styles.interface';\nimport { NumberingLevelModel } from '../../models/generated/numbering-level.model';\nimport { OperationsHistoryInfoModel } from '../editor/operation-history/operations-history-info.model';\nimport { ParagraphStyleModel } from '../../models/generated/paragraph-style.model';\nimport { TextStyleModel } from '../../models/generated/text-style.model';\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    selector: 'app-editor-toolbar',\n    templateUrl: 'editor-toolbar.component.html',\n    styleUrls: ['editor-toolbar.component.scss']\n})\nexport class EditorToolbarComponent {\n    @Input() showActions = true;\n\n    @Input() isViewOnly: boolean;\n\n    @Input() hasSelection: boolean;\n\n    @Input() clipboardData: string;\n\n    @Input() historyInfo: OperationsHistoryInfoModel;\n\n    @Input() styles: IToolbarStyles;\n\n    @Output() openFileFromDisk = new EventEmitter<any>();\n\n    @Output() addCustomElement = new EventEmitter<ElementDataModel>();\n\n    @Output() saveAs = new EventEmitter();\n\n    @Output() print = new EventEmitter<void>();\n\n    @Output() insertPageBreak = new EventEmitter<any>();\n\n    @Output() createDocument = new EventEmitter<any>();\n\n    @Output() insertImage = new EventEmitter<any>();\n\n    @Output() rename = new EventEmitter();\n\n    @Output() delete = new EventEmitter<string>();\n\n    @Output() openEditMenu = new EventEmitter();\n\n    @Output() redo = new EventEmitter<void>();\n\n    @Output() undo = new EventEmitter<void>();\n\n    @Output() cutSelected = new EventEmitter();\n\n    @Output() copySelected = new EventEmitter();\n\n    @Output() pasteClipboardData = new EventEmitter();\n\n    @Output() selectAll = new EventEmitter();\n\n    @Output() removeSelected = new EventEmitter();\n\n    @Output() insertLink = new EventEmitter();\n\n    @Output() createElement = new EventEmitter<ElementDataModel>();\n\n    @Output() changeParagraphStyle = new EventEmitter<ParagraphStyleModel>();\n\n    @Output() changeTextStyle = new EventEmitter<TextStyleModel>();\n\n    @Output() setNumberingTemplateType = new EventEmitter<NumberingLevelModel[]>();\n\n    @Output() removeNumberings = new EventEmitter<void>();\n\n    @Output() insertTable = new EventEmitter<{ rows: number; columns: number }>();\n}\n","<app-menu-dropdowns\n    [isViewOnly]=\"isViewOnly\"\n    [hasSelection]=\"hasSelection\"\n    [clipboardData]=\"clipboardData\"\n    [historyInfo]=\"historyInfo\"\n    [styles]=\"styles\"\n    (openFileFromDisk)=\"openFileFromDisk.emit($event)\"\n    (addCustomElement)=\"addCustomElement.emit($event)\"\n    (saveAs)=\"saveAs.emit()\"\n    (print)=\"print.emit()\"\n    (insertPageBreak)=\"insertPageBreak.emit()\"\n    (createDocument)=\"createDocument.emit()\"\n    (insertImage)=\"insertImage.emit($event)\"\n    (rename)=\"rename.emit()\"\n    (delete)=\"delete.emit()\"\n    (openEditMenu)=\"openEditMenu.emit()\"\n    (redo)=\"redo.emit()\"\n    (undo)=\"undo.emit()\"\n    (cutSelected)=\"cutSelected.emit()\"\n    (copySelected)=\"copySelected.emit()\"\n    (pasteClipboardData)=\"pasteClipboardData.emit()\"\n    (selectAll)=\"selectAll.emit()\"\n    (removeSelected)=\"removeSelected.emit()\"\n    (insertLink)=\"insertLink.emit()\"\n    (createElement)=\"createElement.emit($event)\"\n    (changeParagraphStyle)=\"changeParagraphStyle.emit($event)\"\n    (changeTextStyle)=\"changeTextStyle.emit($event)\"\n    (setNumberingTemplateType)=\"setNumberingTemplateType.emit($event)\"\n    (removeNumberings)=\"removeNumberings.emit()\"\n    (insertTable)=\"insertTable.emit($event)\" />\n<app-toolbar-actions\n    *ngIf=\"styles && showActions\"\n    [isViewOnly]=\"isViewOnly\"\n    [historyInfo]=\"historyInfo\"\n    [styles]=\"styles\"\n    (print)=\"print.emit()\"\n    (redo)=\"redo.emit()\"\n    (undo)=\"undo.emit()\"\n    (changeParagraphStyle)=\"changeParagraphStyle.emit($event)\"\n    (changeTextStyle)=\"changeTextStyle.emit($event)\"\n    (setNumberingTemplateType)=\"setNumberingTemplateType.emit($event)\"\n    (removeNumberings)=\"removeNumberings.emit()\"\n    (createElement)=\"createElement.emit($event)\" />\n"]}
|
|
@@ -18,8 +18,11 @@ import { FontSizeComponent } from './font-size/font-size.component';
|
|
|
18
18
|
import { FontStyleComponent } from './font-style/font-style.component';
|
|
19
19
|
import { FormatComponent } from './format/format.component';
|
|
20
20
|
import { HeadingComponent } from './heading/heading.component';
|
|
21
|
+
import { InsertTableComponent } from '../insert-table/insert-table.component';
|
|
22
|
+
import { MenuDropdownsComponent } from './menu-dropdowns/menu-dropdowns.component';
|
|
21
23
|
import { NumberingComponent } from './numbering/numbering.component';
|
|
22
24
|
import { PrintComponent } from './print/print.component';
|
|
25
|
+
import { ToolbarActionsComponent } from './toolbar-actions/toolbar-actions.component';
|
|
23
26
|
import { UndoRedoComponent } from './undo-redo/undo-redo.component';
|
|
24
27
|
import { ZoomComponent } from './zoom/zoom.component';
|
|
25
28
|
import * as i0 from "@angular/core";
|
|
@@ -37,11 +40,14 @@ export class EditorToolbarModule {
|
|
|
37
40
|
FormatComponent,
|
|
38
41
|
HeadingComponent,
|
|
39
42
|
HeadingComponent,
|
|
43
|
+
MenuDropdownsComponent,
|
|
40
44
|
NumberingComponent,
|
|
41
45
|
PrintComponent,
|
|
46
|
+
ToolbarActionsComponent,
|
|
42
47
|
UndoRedoComponent,
|
|
43
48
|
ZoomComponent], imports: [CommonModule,
|
|
44
49
|
FormsModule,
|
|
50
|
+
InsertTableComponent,
|
|
45
51
|
MatAutocompleteModule,
|
|
46
52
|
MatButtonModule,
|
|
47
53
|
MatButtonToggleModule,
|
|
@@ -54,6 +60,7 @@ export class EditorToolbarModule {
|
|
|
54
60
|
ReactiveFormsModule], exports: [EditorToolbarComponent] }); }
|
|
55
61
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: EditorToolbarModule, providers: [CustomIconService], imports: [CommonModule,
|
|
56
62
|
FormsModule,
|
|
63
|
+
InsertTableComponent,
|
|
57
64
|
MatAutocompleteModule,
|
|
58
65
|
MatButtonModule,
|
|
59
66
|
MatButtonToggleModule,
|
|
@@ -81,14 +88,17 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImpor
|
|
|
81
88
|
FormatComponent,
|
|
82
89
|
HeadingComponent,
|
|
83
90
|
HeadingComponent,
|
|
91
|
+
MenuDropdownsComponent,
|
|
84
92
|
NumberingComponent,
|
|
85
93
|
PrintComponent,
|
|
94
|
+
ToolbarActionsComponent,
|
|
86
95
|
UndoRedoComponent,
|
|
87
96
|
ZoomComponent
|
|
88
97
|
],
|
|
89
98
|
imports: [
|
|
90
99
|
CommonModule,
|
|
91
100
|
FormsModule,
|
|
101
|
+
InsertTableComponent,
|
|
92
102
|
MatAutocompleteModule,
|
|
93
103
|
MatButtonModule,
|
|
94
104
|
MatButtonToggleModule,
|
|
@@ -104,4 +114,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImpor
|
|
|
104
114
|
exports: [EditorToolbarComponent]
|
|
105
115
|
}]
|
|
106
116
|
}] });
|
|
107
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
117
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdG9yLXRvb2xiYXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW5vZGVyL3NyYy9saWIvK3NoYXJlZC9lZGl0b3ItdG9vbGJhci9lZGl0b3ItdG9vbGJhci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN2RSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDeEUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLFlBQVksQ0FBQztBQUU3QyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUM3RSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNwRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUNwRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDdEQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDdkUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzVELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQy9ELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ3JFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQztBQUN0RixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNwRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7O0FBeUN0RCxNQUFNLE9BQU8sbUJBQW1COzhHQUFuQixtQkFBbUI7K0dBQW5CLG1CQUFtQixpQkFyQ3hCLG9CQUFvQjtZQUNwQixzQkFBc0I7WUFDdEIsYUFBYTtZQUNiLGFBQWE7WUFDYixpQkFBaUI7WUFDakIsaUJBQWlCO1lBQ2pCLGtCQUFrQjtZQUNsQixrQkFBa0I7WUFDbEIsZUFBZTtZQUNmLGVBQWU7WUFDZixnQkFBZ0I7WUFDaEIsZ0JBQWdCO1lBQ2hCLHNCQUFzQjtZQUN0QixrQkFBa0I7WUFDbEIsY0FBYztZQUNkLHVCQUF1QjtZQUN2QixpQkFBaUI7WUFDakIsYUFBYSxhQUdiLFlBQVk7WUFDWixXQUFXO1lBQ1gsb0JBQW9CO1lBQ3BCLHFCQUFxQjtZQUNyQixlQUFlO1lBQ2YscUJBQXFCO1lBQ3JCLGFBQWE7WUFDYixjQUFjO1lBQ2QsYUFBYTtZQUNiLGVBQWU7WUFDZixnQkFBZ0I7WUFDaEIsZUFBZTtZQUNmLG1CQUFtQixhQUdiLHNCQUFzQjsrR0FFdkIsbUJBQW1CLGFBSGpCLENBQUMsaUJBQWlCLENBQUMsWUFkMUIsWUFBWTtZQUNaLFdBQVc7WUFDWCxvQkFBb0I7WUFDcEIscUJBQXFCO1lBQ3JCLGVBQWU7WUFDZixxQkFBcUI7WUFDckIsYUFBYTtZQUNiLGNBQWM7WUFDZCxhQUFhO1lBQ2IsZUFBZTtZQUNmLGdCQUFnQjtZQUNoQixlQUFlO1lBQ2YsbUJBQW1COzsyRkFLZCxtQkFBbUI7a0JBdkMvQixRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRTt3QkFDVixvQkFBb0I7d0JBQ3BCLHNCQUFzQjt3QkFDdEIsYUFBYTt3QkFDYixhQUFhO3dCQUNiLGlCQUFpQjt3QkFDakIsaUJBQWlCO3dCQUNqQixrQkFBa0I7d0JBQ2xCLGtCQUFrQjt3QkFDbEIsZUFBZTt3QkFDZixlQUFlO3dCQUNmLGdCQUFnQjt3QkFDaEIsZ0JBQWdCO3dCQUNoQixzQkFBc0I7d0JBQ3RCLGtCQUFrQjt3QkFDbEIsY0FBYzt3QkFDZCx1QkFBdUI7d0JBQ3ZCLGlCQUFpQjt3QkFDakIsYUFBYTtxQkFDaEI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxvQkFBb0I7d0JBQ3BCLHFCQUFxQjt3QkFDckIsZUFBZTt3QkFDZixxQkFBcUI7d0JBQ3JCLGFBQWE7d0JBQ2IsY0FBYzt3QkFDZCxhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsZ0JBQWdCO3dCQUNoQixlQUFlO3dCQUNmLG1CQUFtQjtxQkFDdEI7b0JBQ0QsU0FBUyxFQUFFLENBQUMsaUJBQWlCLENBQUM7b0JBQzlCLE9BQU8sRUFBRSxDQUFDLHNCQUFzQixDQUFDO2lCQUNwQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IE1hdEF1dG9jb21wbGV0ZU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2F1dG9jb21wbGV0ZSc7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTWF0QnV0dG9uVG9nZ2xlTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uLXRvZ2dsZSc7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyBNYXRJbnB1dE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2lucHV0JztcbmltcG9ydCB7IE1hdE1lbnVNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9tZW51JztcbmltcG9ydCB7IE1hdFNlbGVjdE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3NlbGVjdCc7XG5pbXBvcnQgeyBNYXRUb29sYmFyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdG9vbGJhcic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmd4Q29sb3JzTW9kdWxlIH0gZnJvbSAnbmd4LWNvbG9ycyc7XG5cbmltcG9ydCB7IENvbG9yUGlja2VyQ29tcG9uZW50IH0gZnJvbSAnLi9jb2xvci1waWNrZXIvY29sb3ItcGlja2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDdXN0b21JY29uU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL2N1c3RvbS1pY29uLnNlcnZpY2UnO1xuaW1wb3J0IHsgRWRpdG9yVG9vbGJhckNvbXBvbmVudCB9IGZyb20gJy4vZWRpdG9yLXRvb2xiYXIuY29tcG9uZW50JztcbmltcG9ydCB7IEZvbnRDb21wb25lbnQgfSBmcm9tICcuL2ZvbnQvZm9udC5jb21wb25lbnQnO1xuaW1wb3J0IHsgRm9udFNpemVDb21wb25lbnQgfSBmcm9tICcuL2ZvbnQtc2l6ZS9mb250LXNpemUuY29tcG9uZW50JztcbmltcG9ydCB7IEZvbnRTdHlsZUNvbXBvbmVudCB9IGZyb20gJy4vZm9udC1zdHlsZS9mb250LXN0eWxlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBGb3JtYXRDb21wb25lbnQgfSBmcm9tICcuL2Zvcm1hdC9mb3JtYXQuY29tcG9uZW50JztcbmltcG9ydCB7IEhlYWRpbmdDb21wb25lbnQgfSBmcm9tICcuL2hlYWRpbmcvaGVhZGluZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgSW5zZXJ0VGFibGVDb21wb25lbnQgfSBmcm9tICcuLi9pbnNlcnQtdGFibGUvaW5zZXJ0LXRhYmxlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBNZW51RHJvcGRvd25zQ29tcG9uZW50IH0gZnJvbSAnLi9tZW51LWRyb3Bkb3ducy9tZW51LWRyb3Bkb3ducy5jb21wb25lbnQnO1xuaW1wb3J0IHsgTnVtYmVyaW5nQ29tcG9uZW50IH0gZnJvbSAnLi9udW1iZXJpbmcvbnVtYmVyaW5nLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBQcmludENvbXBvbmVudCB9IGZyb20gJy4vcHJpbnQvcHJpbnQuY29tcG9uZW50JztcbmltcG9ydCB7IFRvb2xiYXJBY3Rpb25zQ29tcG9uZW50IH0gZnJvbSAnLi90b29sYmFyLWFjdGlvbnMvdG9vbGJhci1hY3Rpb25zLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBVbmRvUmVkb0NvbXBvbmVudCB9IGZyb20gJy4vdW5kby1yZWRvL3VuZG8tcmVkby5jb21wb25lbnQnO1xuaW1wb3J0IHsgWm9vbUNvbXBvbmVudCB9IGZyb20gJy4vem9vbS96b29tLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbXG4gICAgICAgIENvbG9yUGlja2VyQ29tcG9uZW50LFxuICAgICAgICBFZGl0b3JUb29sYmFyQ29tcG9uZW50LFxuICAgICAgICBGb250Q29tcG9uZW50LFxuICAgICAgICBGb250Q29tcG9uZW50LFxuICAgICAgICBGb250U2l6ZUNvbXBvbmVudCxcbiAgICAgICAgRm9udFNpemVDb21wb25lbnQsXG4gICAgICAgIEZvbnRTdHlsZUNvbXBvbmVudCxcbiAgICAgICAgRm9udFN0eWxlQ29tcG9uZW50LFxuICAgICAgICBGb3JtYXRDb21wb25lbnQsXG4gICAgICAgIEZvcm1hdENvbXBvbmVudCxcbiAgICAgICAgSGVhZGluZ0NvbXBvbmVudCxcbiAgICAgICAgSGVhZGluZ0NvbXBvbmVudCxcbiAgICAgICAgTWVudURyb3Bkb3duc0NvbXBvbmVudCxcbiAgICAgICAgTnVtYmVyaW5nQ29tcG9uZW50LFxuICAgICAgICBQcmludENvbXBvbmVudCxcbiAgICAgICAgVG9vbGJhckFjdGlvbnNDb21wb25lbnQsXG4gICAgICAgIFVuZG9SZWRvQ29tcG9uZW50LFxuICAgICAgICBab29tQ29tcG9uZW50XG4gICAgXSxcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIENvbW1vbk1vZHVsZSxcbiAgICAgICAgRm9ybXNNb2R1bGUsXG4gICAgICAgIEluc2VydFRhYmxlQ29tcG9uZW50LFxuICAgICAgICBNYXRBdXRvY29tcGxldGVNb2R1bGUsXG4gICAgICAgIE1hdEJ1dHRvbk1vZHVsZSxcbiAgICAgICAgTWF0QnV0dG9uVG9nZ2xlTW9kdWxlLFxuICAgICAgICBNYXRJY29uTW9kdWxlLFxuICAgICAgICBNYXRJbnB1dE1vZHVsZSxcbiAgICAgICAgTWF0TWVudU1vZHVsZSxcbiAgICAgICAgTWF0U2VsZWN0TW9kdWxlLFxuICAgICAgICBNYXRUb29sYmFyTW9kdWxlLFxuICAgICAgICBOZ3hDb2xvcnNNb2R1bGUsXG4gICAgICAgIFJlYWN0aXZlRm9ybXNNb2R1bGVcbiAgICBdLFxuICAgIHByb3ZpZGVyczogW0N1c3RvbUljb25TZXJ2aWNlXSxcbiAgICBleHBvcnRzOiBbRWRpdG9yVG9vbGJhckNvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgRWRpdG9yVG9vbGJhck1vZHVsZSB7fVxuIl19
|
|
@@ -30,11 +30,11 @@ export class FontComponent {
|
|
|
30
30
|
this.selectFont.emit(font);
|
|
31
31
|
}
|
|
32
32
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: FontComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
33
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: FontComponent, selector: "app-font", inputs: { isDisabled: "isDisabled", styles: "styles" }, outputs: { selectFont: "selectFont" }, ngImport: i0, template: "<button\n mat-button\n [matMenuTriggerFor]=\"fontMenu\"\n [matMenuTriggerRestoreFocus]=\"false\">\n <div class=\"font-menu\">\n <span>{{ font }}</span>\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-arrow-dropdown\"></mat-icon>\n </div>\n</button>\n<mat-menu
|
|
33
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: FontComponent, selector: "app-font", inputs: { isDisabled: "isDisabled", styles: "styles" }, outputs: { selectFont: "selectFont" }, ngImport: i0, template: "<button\n mat-button\n [matMenuTriggerFor]=\"fontMenu\"\n [matMenuTriggerRestoreFocus]=\"false\">\n <div class=\"font-menu\">\n <span>{{ font }}</span>\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-arrow-dropdown\"></mat-icon>\n </div>\n</button>\n<mat-menu\n #fontMenu=\"matMenu\"\n class=\"noder-modal\">\n <ng-container *ngFor=\"let font of fonts\">\n <button\n mat-menu-item\n [disabled]=\"isDisabled\"\n (click)=\"onSelectFont(font)\">\n {{ font }}\n </button>\n </ng-container>\n</mat-menu>\n", styles: [".font-menu{display:flex;justify-content:space-between;align-items:center;min-width:130px}span{padding-left:10%}button{height:28px;margin:0 4px}mat-icon{margin-right:5%}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i2.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i4.MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: i4.MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i4.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
34
34
|
}
|
|
35
35
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: FontComponent, decorators: [{
|
|
36
36
|
type: Component,
|
|
37
|
-
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'app-font', template: "<button\n mat-button\n [matMenuTriggerFor]=\"fontMenu\"\n [matMenuTriggerRestoreFocus]=\"false\">\n <div class=\"font-menu\">\n <span>{{ font }}</span>\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-arrow-dropdown\"></mat-icon>\n </div>\n</button>\n<mat-menu
|
|
37
|
+
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'app-font', template: "<button\n mat-button\n [matMenuTriggerFor]=\"fontMenu\"\n [matMenuTriggerRestoreFocus]=\"false\">\n <div class=\"font-menu\">\n <span>{{ font }}</span>\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-arrow-dropdown\"></mat-icon>\n </div>\n</button>\n<mat-menu\n #fontMenu=\"matMenu\"\n class=\"noder-modal\">\n <ng-container *ngFor=\"let font of fonts\">\n <button\n mat-menu-item\n [disabled]=\"isDisabled\"\n (click)=\"onSelectFont(font)\">\n {{ font }}\n </button>\n </ng-container>\n</mat-menu>\n", styles: [".font-menu{display:flex;justify-content:space-between;align-items:center;min-width:130px}span{padding-left:10%}button{height:28px;margin:0 4px}mat-icon{margin-right:5%}\n"] }]
|
|
38
38
|
}], propDecorators: { isDisabled: [{
|
|
39
39
|
type: Input
|
|
40
40
|
}], styles: [{
|
|
@@ -42,4 +42,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImpor
|
|
|
42
42
|
}], selectFont: [{
|
|
43
43
|
type: Output
|
|
44
44
|
}] } });
|
|
45
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9udC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbm9kZXIvc3JjL2xpYi8rc2hhcmVkL2VkaXRvci10b29sYmFyL2ZvbnQvZm9udC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbm9kZXIvc3JjL2xpYi8rc2hhcmVkL2VkaXRvci10b29sYmFyL2ZvbnQvZm9udC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRWhHLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDBDQUEwQyxDQUFDOzs7Ozs7QUFTbEcsTUFBTSxPQUFPLGFBQWE7SUFOMUI7UUFPYSxlQUFVLEdBQUcsS0FBSyxDQUFDO1FBbUJsQixlQUFVLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztRQUVsRCxVQUFLLEdBQUcsQ0FBQyxtQkFBbUIsRUFBRSxTQUFTLEVBQUUsT0FBTyxFQUFFLGlCQUFpQixDQUFDLENBQUM7UUFFckUsU0FBSSxHQUFHLG1CQUFtQixDQUFDO0tBSzlCO0lBMUJHLElBQ0ksTUFBTSxDQUFDLEtBQXFCO1FBQzVCLElBQUksQ0FBQyxLQUFLLEVBQUUsVUFBVSxFQUFFO1lBQ3BCLE9BQU87U0FDVjtRQUVELEtBQUssSUFBSSxVQUFVLElBQUksS0FBSyxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDakQsTUFBTSxNQUFNLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7WUFDN0MsTUFBTSxJQUFJLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7WUFDdkMsTUFBTSxVQUFVLEdBQUcsR0FBRyxNQUFNLEdBQUcsSUFBSSxHQUFHLEtBQUssQ0FBQyxRQUFRLElBQUksaUJBQWlCLE1BQU0sVUFBVSxFQUFFLENBQUM7WUFDNUYsSUFBSSxRQUFRLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsRUFBRTtnQkFDbEMsSUFBSSxDQUFDLElBQUksR0FBRyxVQUFVLENBQUMsVUFBVSxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsQ0FBQztnQkFDM0MsT0FBTzthQUNWO1NBQ0o7SUFDTCxDQUFDO0lBUUQsWUFBWSxDQUFDLElBQVk7UUFDckIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDL0IsQ0FBQzs4R0E1QlEsYUFBYTtrR0FBYixhQUFhLCtJQ1gxQixtbkJBdUJBOzsyRkRaYSxhQUFhO2tCQU56QixTQUFTO3NDQUNXLHVCQUF1QixDQUFDLE1BQU0sWUFDckMsVUFBVTs4QkFLWCxVQUFVO3NCQUFsQixLQUFLO2dCQUdGLE1BQU07c0JBRFQsS0FBSztnQkFpQkksVUFBVTtzQkFBbkIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBERUZBVUxUX0ZPTlRfRkFNSUxZLCBERUZBVUxUX0ZPTlRfU0laRSB9IGZyb20gJy4uLy4uL2VkaXRvci9jb3JlL2NvbnN0YW50cy9lZGl0b3IuY29uc3QnO1xuaW1wb3J0IHsgSVRvb2xiYXJTdHlsZXMgfSBmcm9tICcuLi8uLi9lZGl0b3IvY29yZS9pbnRlcmZhY2VzL3Rvb2xiYXItc3R5bGVzLmludGVyZmFjZSc7XG5cbkBDb21wb25lbnQoe1xuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIHNlbGVjdG9yOiAnYXBwLWZvbnQnLFxuICAgIHRlbXBsYXRlVXJsOiAnZm9udC5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJ2ZvbnQuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBGb250Q29tcG9uZW50IHtcbiAgICBASW5wdXQoKSBpc0Rpc2FibGVkID0gZmFsc2U7XG5cbiAgICBASW5wdXQoKVxuICAgIHNldCBzdHlsZXModmFsdWU6IElUb29sYmFyU3R5bGVzKSB7XG4gICAgICAgIGlmICghdmFsdWU/LmZvbnRGYW1pbHkpIHtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGZvciAobGV0IGZvbnRGYW1pbHkgb2YgdmFsdWUuZm9udEZhbWlseS5zcGxpdCgnLCAnKSkge1xuICAgICAgICAgICAgY29uc3QgaXRhbGljID0gdmFsdWUuaXRhbGljID8gJ2l0YWxpYyAnIDogJyc7XG4gICAgICAgICAgICBjb25zdCBib2xkID0gdmFsdWUuYm9sZCA/ICdib2xkICcgOiAnJztcbiAgICAgICAgICAgIGNvbnN0IGZvbnRTdHlsZXMgPSBgJHtpdGFsaWN9JHtib2xkfSR7dmFsdWUuZm9udFNpemUgPz8gREVGQVVMVF9GT05UX1NJWkV9cHQgJHtmb250RmFtaWx5fWA7XG4gICAgICAgICAgICBpZiAoZG9jdW1lbnQuZm9udHMuY2hlY2soZm9udFN0eWxlcykpIHtcbiAgICAgICAgICAgICAgICB0aGlzLmZvbnQgPSBmb250RmFtaWx5LnJlcGxhY2VBbGwoJ1wiJywgJycpO1xuICAgICAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgIH1cblxuICAgIEBPdXRwdXQoKSBzZWxlY3RGb250ID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmc+KCk7XG5cbiAgICBmb250cyA9IFtERUZBVUxUX0ZPTlRfRkFNSUxZLCAnVmVyZGFuYScsICdBcmlhbCcsICdUaW1lcyBOZXcgUm9tYW4nXTtcblxuICAgIGZvbnQgPSBERUZBVUxUX0ZPTlRfRkFNSUxZO1xuXG4gICAgb25TZWxlY3RGb250KGZvbnQ6IHN0cmluZyk6IHZvaWQge1xuICAgICAgICB0aGlzLnNlbGVjdEZvbnQuZW1pdChmb250KTtcbiAgICB9XG59XG4iLCI8YnV0dG9uXG4gICAgbWF0LWJ1dHRvblxuICAgIFttYXRNZW51VHJpZ2dlckZvcl09XCJmb250TWVudVwiXG4gICAgW21hdE1lbnVUcmlnZ2VyUmVzdG9yZUZvY3VzXT1cImZhbHNlXCI+XG4gICAgPGRpdiBjbGFzcz1cImZvbnQtbWVudVwiPlxuICAgICAgICA8c3Bhbj57eyBmb250IH19PC9zcGFuPlxuICAgICAgICA8bWF0LWljb25cbiAgICAgICAgICAgIGZvbnRTZXQ9XCJuYy1pY29uXCJcbiAgICAgICAgICAgIGZvbnRJY29uPVwiaWNvbi1hcnJvdy1kcm9wZG93blwiPjwvbWF0LWljb24+XG4gICAgPC9kaXY+XG48L2J1dHRvbj5cbjxtYXQtbWVudVxuICAgICNmb250TWVudT1cIm1hdE1lbnVcIlxuICAgIGNsYXNzPVwibm9kZXItbW9kYWxcIj5cbiAgICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBmb250IG9mIGZvbnRzXCI+XG4gICAgICAgIDxidXR0b25cbiAgICAgICAgICAgIG1hdC1tZW51LWl0ZW1cbiAgICAgICAgICAgIFtkaXNhYmxlZF09XCJpc0Rpc2FibGVkXCJcbiAgICAgICAgICAgIChjbGljayk9XCJvblNlbGVjdEZvbnQoZm9udClcIj5cbiAgICAgICAgICAgIHt7IGZvbnQgfX1cbiAgICAgICAgPC9idXR0b24+XG4gICAgPC9uZy1jb250YWluZXI+XG48L21hdC1tZW51PlxuIl19
|
|
@@ -67,11 +67,11 @@ export class FontSizeComponent {
|
|
|
67
67
|
}
|
|
68
68
|
}
|
|
69
69
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: FontSizeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
70
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: FontSizeComponent, selector: "app-font-size", inputs: { isDisabled: "isDisabled", fontSize: "fontSize" }, outputs: { selectFontSize: "selectFontSize" }, viewQueries: [{ propertyName: "autocomplete", first: true, predicate: ["auto"], descendants: true }], ngImport: i0, template: "<button\n mat-button\n [disabled]=\"!fontSize || isDisabled\"\n (click)=\"onDecrementFontSize()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-remove\"></mat-icon>\n</button>\n<input\n type=\"text\"\n [formControl]=\"fontSizeControl\"\n [matAutocomplete]=\"auto\"\n (keyup.enter)=\"onSetFontSize()\"\n (blur)=\"resetFontSize()\" />\n<mat-autocomplete\n #auto=\"matAutocomplete\"\n panelWidth=\"60\"\n disableRipple=\"false\"\n hideSingleSelectionIndicator=\"true\">\n <mat-option\n *ngFor=\"let fontSize of fontSizes\"\n [value]=\"fontSize\"\n (click)=\"onSelectFontSize(fontSize)\">\n {{ fontSize }}\n </mat-option>\n</mat-autocomplete>\n<button\n mat-button\n [disabled]=\"!fontSize || isDisabled\"\n (click)=\"onIncrementFontSize()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-add\"></mat-icon>\n</button>\n", styles: ["
|
|
70
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: FontSizeComponent, selector: "app-font-size", inputs: { isDisabled: "isDisabled", fontSize: "fontSize" }, outputs: { selectFontSize: "selectFontSize" }, viewQueries: [{ propertyName: "autocomplete", first: true, predicate: ["auto"], descendants: true }], ngImport: i0, template: "<button\n mat-button\n [disabled]=\"!fontSize || isDisabled\"\n (click)=\"onDecrementFontSize()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-remove\"></mat-icon>\n</button>\n<input\n type=\"text\"\n [formControl]=\"fontSizeControl\"\n [matAutocomplete]=\"auto\"\n (keyup.enter)=\"onSetFontSize()\"\n (blur)=\"resetFontSize()\" />\n<mat-autocomplete\n #auto=\"matAutocomplete\"\n panelWidth=\"60\"\n disableRipple=\"false\"\n hideSingleSelectionIndicator=\"true\">\n <mat-option\n *ngFor=\"let fontSize of fontSizes\"\n [value]=\"fontSize\"\n (click)=\"onSelectFontSize(fontSize)\">\n {{ fontSize }}\n </mat-option>\n</mat-autocomplete>\n<button\n mat-button\n [disabled]=\"!fontSize || isDisabled\"\n (click)=\"onIncrementFontSize()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-add\"></mat-icon>\n</button>\n", styles: ["button{margin:4px}input{width:48px;height:32px;text-align:center;border-color:transparent;outline-color:#1b84e0}.mdc-button{min-width:32px;min-height:32px;width:32px;height:32px;padding:0}.mat-mdc-button>.mat-icon{margin-right:0;font-size:24px;height:24px;width:24px}.mat-mdc-option{padding-left:6px;padding-right:6px;min-height:30px}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "component", type: i3.MatAutocomplete, selector: "mat-autocomplete", inputs: ["aria-label", "aria-labelledby", "displayWith", "autoActiveFirstOption", "autoSelectActiveOption", "requireSelection", "panelWidth", "disableRipple", "class", "hideSingleSelectionIndicator"], outputs: ["optionSelected", "opened", "closed", "optionActivated"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i4.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i3.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }, { kind: "component", type: i5.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
71
71
|
}
|
|
72
72
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: FontSizeComponent, decorators: [{
|
|
73
73
|
type: Component,
|
|
74
|
-
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'app-font-size', template: "<button\n mat-button\n [disabled]=\"!fontSize || isDisabled\"\n (click)=\"onDecrementFontSize()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-remove\"></mat-icon>\n</button>\n<input\n type=\"text\"\n [formControl]=\"fontSizeControl\"\n [matAutocomplete]=\"auto\"\n (keyup.enter)=\"onSetFontSize()\"\n (blur)=\"resetFontSize()\" />\n<mat-autocomplete\n #auto=\"matAutocomplete\"\n panelWidth=\"60\"\n disableRipple=\"false\"\n hideSingleSelectionIndicator=\"true\">\n <mat-option\n *ngFor=\"let fontSize of fontSizes\"\n [value]=\"fontSize\"\n (click)=\"onSelectFontSize(fontSize)\">\n {{ fontSize }}\n </mat-option>\n</mat-autocomplete>\n<button\n mat-button\n [disabled]=\"!fontSize || isDisabled\"\n (click)=\"onIncrementFontSize()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-add\"></mat-icon>\n</button>\n", styles: ["
|
|
74
|
+
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'app-font-size', template: "<button\n mat-button\n [disabled]=\"!fontSize || isDisabled\"\n (click)=\"onDecrementFontSize()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-remove\"></mat-icon>\n</button>\n<input\n type=\"text\"\n [formControl]=\"fontSizeControl\"\n [matAutocomplete]=\"auto\"\n (keyup.enter)=\"onSetFontSize()\"\n (blur)=\"resetFontSize()\" />\n<mat-autocomplete\n #auto=\"matAutocomplete\"\n panelWidth=\"60\"\n disableRipple=\"false\"\n hideSingleSelectionIndicator=\"true\">\n <mat-option\n *ngFor=\"let fontSize of fontSizes\"\n [value]=\"fontSize\"\n (click)=\"onSelectFontSize(fontSize)\">\n {{ fontSize }}\n </mat-option>\n</mat-autocomplete>\n<button\n mat-button\n [disabled]=\"!fontSize || isDisabled\"\n (click)=\"onIncrementFontSize()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-add\"></mat-icon>\n</button>\n", styles: ["button{margin:4px}input{width:48px;height:32px;text-align:center;border-color:transparent;outline-color:#1b84e0}.mdc-button{min-width:32px;min-height:32px;width:32px;height:32px;padding:0}.mat-mdc-button>.mat-icon{margin-right:0;font-size:24px;height:24px;width:24px}.mat-mdc-option{padding-left:6px;padding-right:6px;min-height:30px}\n"] }]
|
|
75
75
|
}], propDecorators: { isDisabled: [{
|
|
76
76
|
type: Input
|
|
77
77
|
}], fontSize: [{
|
|
@@ -49,11 +49,11 @@ export class FontStyleComponent {
|
|
|
49
49
|
this.selectHighlightColor.emit(color);
|
|
50
50
|
}
|
|
51
51
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: FontStyleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
52
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: FontStyleComponent, selector: "app-font-style", inputs: { isDisabled: "isDisabled", bold: "bold", italic: "italic", underline: "underline", fontColor: "fontColor", highlightColor: "highlightColor" }, outputs: { toggleBold: "toggleBold", toggleItalic: "toggleItalic", toggleUnderline: "toggleUnderline", selectFontColor: "selectFontColor", selectHighlightColor: "selectHighlightColor" }, ngImport: i0, template: "<mat-button-toggle-group multiple>\n <mat-button-toggle\n [disabled]=\"isDisabled\"\n [checked]=\"bold\"\n (click)=\"onToggleBold()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-format-bold\"></mat-icon>\n </mat-button-toggle>\n <mat-button-toggle\n [disabled]=\"isDisabled\"\n [checked]=\"italic\"\n (click)=\"onToggleItalic()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-format-italic\"></mat-icon>\n </mat-button-toggle>\n <mat-button-toggle\n [disabled]=\"isDisabled\"\n [checked]=\"underline\"\n (click)=\"onToggleUnderline()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-format-underlined\"></mat-icon>\n </mat-button-toggle>\n</mat-button-toggle-group>\n<app-color-picker\n id=\"icon-format-colortext\"\n class=\"text-color\"\n [color]=\"fontColor\"\n [isDisabled]=\"isDisabled\"\n icon=\"icon-format-colortext\"\n [palette]=\"textColorPalette\"\n (colorChange)=\"onSelectFontColor($event)\"></app-color-picker>\n<app-color-picker\n id=\"icon-link-highlighter\"\n class=\"highlight-color\"\n [color]=\"highlightColor\"\n [isDisabled]=\"isDisabled\"\n icon=\"icon-link-highlighter\"\n [palette]=\"highlightColorPalette\"\n (colorChange)=\"onSelectHighlightColor($event)\"></app-color-picker>\n", styles: ["mat-button-toggle,button{margin:0 4px}.mat-button-toggle-group-appearance-standard .mat-button-toggle+.mat-button-toggle{border-left:0}.mat-button-toggle-standalone.mat-button-toggle-appearance-standard,.mat-button-toggle-group-appearance-standard{border:0}:host{align-
|
|
52
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: FontStyleComponent, selector: "app-font-style", inputs: { isDisabled: "isDisabled", bold: "bold", italic: "italic", underline: "underline", fontColor: "fontColor", highlightColor: "highlightColor" }, outputs: { toggleBold: "toggleBold", toggleItalic: "toggleItalic", toggleUnderline: "toggleUnderline", selectFontColor: "selectFontColor", selectHighlightColor: "selectHighlightColor" }, ngImport: i0, template: "<mat-button-toggle-group multiple>\n <mat-button-toggle\n [disabled]=\"isDisabled\"\n [checked]=\"bold\"\n (click)=\"onToggleBold()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-format-bold\"></mat-icon>\n </mat-button-toggle>\n <mat-button-toggle\n [disabled]=\"isDisabled\"\n [checked]=\"italic\"\n (click)=\"onToggleItalic()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-format-italic\"></mat-icon>\n </mat-button-toggle>\n <mat-button-toggle\n [disabled]=\"isDisabled\"\n [checked]=\"underline\"\n (click)=\"onToggleUnderline()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-format-underlined\"></mat-icon>\n </mat-button-toggle>\n</mat-button-toggle-group>\n<app-color-picker\n id=\"icon-format-colortext\"\n class=\"text-color\"\n [color]=\"fontColor\"\n [isDisabled]=\"isDisabled\"\n icon=\"icon-format-colortext\"\n [palette]=\"textColorPalette\"\n (colorChange)=\"onSelectFontColor($event)\"></app-color-picker>\n<app-color-picker\n id=\"icon-link-highlighter\"\n class=\"highlight-color\"\n [color]=\"highlightColor\"\n [isDisabled]=\"isDisabled\"\n icon=\"icon-link-highlighter\"\n [palette]=\"highlightColorPalette\"\n (colorChange)=\"onSelectHighlightColor($event)\"></app-color-picker>\n", styles: ["mat-button-toggle,button{margin:0 4px}.mat-button-toggle-group-appearance-standard .mat-button-toggle+.mat-button-toggle{border-left:0}.mat-button-toggle-standalone.mat-button-toggle-appearance-standard,.mat-button-toggle-group-appearance-standard{border:0}:host{display:flex;align-items:center}:host ::ng-deep #format-color-highlight .circle.button:first-child,:host ::ng-deep #format-color-highlight .circle.wrapper.color:first-child{flex:100%;width:100%;background:no-repeat left/20px url(https://cdn3.iconfinder.com/data/icons/google-material-design-icons/48/ic_format_color_reset_48px-512.png);border-radius:unset}:host ::ng-deep #format-color-highlight .circle.button:first-child .circle.color.circle-border,:host ::ng-deep #format-color-highlight .circle.wrapper.color:first-child .circle.color.circle-border{width:100%;border:unset}:host ::ng-deep #format-color-highlight .circle.button:first-child .circle.color.circle-border .selected,:host ::ng-deep #format-color-highlight .circle.wrapper.color:first-child .circle.color.circle-border .selected{display:none}\n"], dependencies: [{ kind: "directive", type: i1.MatButtonToggleGroup, selector: "mat-button-toggle-group", inputs: ["appearance", "name", "vertical", "value", "multiple", "disabled"], outputs: ["valueChange", "change"], exportAs: ["matButtonToggleGroup"] }, { kind: "component", type: i1.MatButtonToggle, selector: "mat-button-toggle", inputs: ["aria-label", "aria-labelledby", "id", "name", "value", "tabIndex", "disableRipple", "appearance", "checked", "disabled"], outputs: ["change"], exportAs: ["matButtonToggle"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3.ColorPickerComponent, selector: "app-color-picker", inputs: ["color", "icon", "isDisabled", "palette"], outputs: ["colorChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
53
53
|
}
|
|
54
54
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: FontStyleComponent, decorators: [{
|
|
55
55
|
type: Component,
|
|
56
|
-
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'app-font-style', template: "<mat-button-toggle-group multiple>\n <mat-button-toggle\n [disabled]=\"isDisabled\"\n [checked]=\"bold\"\n (click)=\"onToggleBold()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-format-bold\"></mat-icon>\n </mat-button-toggle>\n <mat-button-toggle\n [disabled]=\"isDisabled\"\n [checked]=\"italic\"\n (click)=\"onToggleItalic()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-format-italic\"></mat-icon>\n </mat-button-toggle>\n <mat-button-toggle\n [disabled]=\"isDisabled\"\n [checked]=\"underline\"\n (click)=\"onToggleUnderline()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-format-underlined\"></mat-icon>\n </mat-button-toggle>\n</mat-button-toggle-group>\n<app-color-picker\n id=\"icon-format-colortext\"\n class=\"text-color\"\n [color]=\"fontColor\"\n [isDisabled]=\"isDisabled\"\n icon=\"icon-format-colortext\"\n [palette]=\"textColorPalette\"\n (colorChange)=\"onSelectFontColor($event)\"></app-color-picker>\n<app-color-picker\n id=\"icon-link-highlighter\"\n class=\"highlight-color\"\n [color]=\"highlightColor\"\n [isDisabled]=\"isDisabled\"\n icon=\"icon-link-highlighter\"\n [palette]=\"highlightColorPalette\"\n (colorChange)=\"onSelectHighlightColor($event)\"></app-color-picker>\n", styles: ["mat-button-toggle,button{margin:0 4px}.mat-button-toggle-group-appearance-standard .mat-button-toggle+.mat-button-toggle{border-left:0}.mat-button-toggle-standalone.mat-button-toggle-appearance-standard,.mat-button-toggle-group-appearance-standard{border:0}:host{align-
|
|
56
|
+
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'app-font-style', template: "<mat-button-toggle-group multiple>\n <mat-button-toggle\n [disabled]=\"isDisabled\"\n [checked]=\"bold\"\n (click)=\"onToggleBold()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-format-bold\"></mat-icon>\n </mat-button-toggle>\n <mat-button-toggle\n [disabled]=\"isDisabled\"\n [checked]=\"italic\"\n (click)=\"onToggleItalic()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-format-italic\"></mat-icon>\n </mat-button-toggle>\n <mat-button-toggle\n [disabled]=\"isDisabled\"\n [checked]=\"underline\"\n (click)=\"onToggleUnderline()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-format-underlined\"></mat-icon>\n </mat-button-toggle>\n</mat-button-toggle-group>\n<app-color-picker\n id=\"icon-format-colortext\"\n class=\"text-color\"\n [color]=\"fontColor\"\n [isDisabled]=\"isDisabled\"\n icon=\"icon-format-colortext\"\n [palette]=\"textColorPalette\"\n (colorChange)=\"onSelectFontColor($event)\"></app-color-picker>\n<app-color-picker\n id=\"icon-link-highlighter\"\n class=\"highlight-color\"\n [color]=\"highlightColor\"\n [isDisabled]=\"isDisabled\"\n icon=\"icon-link-highlighter\"\n [palette]=\"highlightColorPalette\"\n (colorChange)=\"onSelectHighlightColor($event)\"></app-color-picker>\n", styles: ["mat-button-toggle,button{margin:0 4px}.mat-button-toggle-group-appearance-standard .mat-button-toggle+.mat-button-toggle{border-left:0}.mat-button-toggle-standalone.mat-button-toggle-appearance-standard,.mat-button-toggle-group-appearance-standard{border:0}:host{display:flex;align-items:center}:host ::ng-deep #format-color-highlight .circle.button:first-child,:host ::ng-deep #format-color-highlight .circle.wrapper.color:first-child{flex:100%;width:100%;background:no-repeat left/20px url(https://cdn3.iconfinder.com/data/icons/google-material-design-icons/48/ic_format_color_reset_48px-512.png);border-radius:unset}:host ::ng-deep #format-color-highlight .circle.button:first-child .circle.color.circle-border,:host ::ng-deep #format-color-highlight .circle.wrapper.color:first-child .circle.color.circle-border{width:100%;border:unset}:host ::ng-deep #format-color-highlight .circle.button:first-child .circle.color.circle-border .selected,:host ::ng-deep #format-color-highlight .circle.wrapper.color:first-child .circle.color.circle-border .selected{display:none}\n"] }]
|
|
57
57
|
}], propDecorators: { isDisabled: [{
|
|
58
58
|
type: Input
|
|
59
59
|
}], bold: [{
|