@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.
Files changed (75) hide show
  1. package/README.md +72 -64
  2. package/esm2022/lib/+shared/add-link-dialog/add-link-dialog.component.mjs +9 -5
  3. package/esm2022/lib/+shared/confirm-dialog/confirm-dialog.component.mjs +10 -6
  4. package/esm2022/lib/+shared/editor/core/editor.mjs +7 -14
  5. package/esm2022/lib/+shared/editor/core/helpers/rendering.helper.mjs +9 -8
  6. package/esm2022/lib/+shared/editor/core/layers/text.layer.mjs +4 -4
  7. package/esm2022/lib/+shared/editor/custom-components/image/components/image.component.mjs +4 -3
  8. package/esm2022/lib/+shared/editor/custom-components/shared/abstract/base.component.mjs +4 -2
  9. package/esm2022/lib/+shared/editor/custom-components/shared/services/custom-content/custom-content.service.mjs +6 -12
  10. package/esm2022/lib/+shared/editor/custom-components/tab/tab.component.mjs +3 -2
  11. package/esm2022/lib/+shared/editor/custom-components/table/components/table-cell.component.mjs +6 -4
  12. package/esm2022/lib/+shared/editor/custom-components/table/components/table.component.mjs +7 -5
  13. package/esm2022/lib/+shared/editor/editor.component.mjs +5 -12
  14. package/esm2022/lib/+shared/editor/editor.module.mjs +1 -4
  15. package/esm2022/lib/+shared/editor/execution/models/general-properties.model.mjs +1 -1
  16. package/esm2022/lib/+shared/editor/execution/regulator.service.mjs +15 -5
  17. package/esm2022/lib/+shared/editor-title/editor-title.component.mjs +83 -0
  18. package/esm2022/lib/+shared/editor-toolbar/color-picker/color-picker.component.mjs +2 -2
  19. package/esm2022/lib/+shared/editor-toolbar/editor-toolbar.component.mjs +77 -91
  20. package/esm2022/lib/+shared/editor-toolbar/editor-toolbar.module.mjs +11 -1
  21. package/esm2022/lib/+shared/editor-toolbar/font/font.component.mjs +3 -3
  22. package/esm2022/lib/+shared/editor-toolbar/font-size/font-size.component.mjs +2 -2
  23. package/esm2022/lib/+shared/editor-toolbar/font-style/font-style.component.mjs +2 -2
  24. package/esm2022/lib/+shared/editor-toolbar/menu-dropdowns/menu-dropdowns.component.mjs +194 -0
  25. package/esm2022/lib/+shared/editor-toolbar/numbering/numbering.component.mjs +3 -3
  26. package/esm2022/lib/+shared/editor-toolbar/print/print.component.mjs +2 -2
  27. package/esm2022/lib/+shared/editor-toolbar/toolbar-actions/toolbar-actions.component.mjs +126 -0
  28. package/esm2022/lib/+shared/editor-toolbar/undo-redo/undo-redo.component.mjs +2 -2
  29. package/esm2022/lib/+shared/helpers/scaling.helper.mjs +9 -0
  30. package/esm2022/public-api.mjs +2 -2
  31. package/fesm2022/talrace-ngx-noder.mjs +455 -398
  32. package/fesm2022/talrace-ngx-noder.mjs.map +1 -1
  33. package/lib/+shared/add-link-dialog/add-link-dialog.component.d.ts +1 -0
  34. package/lib/+shared/confirm-dialog/confirm-dialog.component.d.ts +1 -0
  35. package/lib/+shared/editor/core/editor.d.ts +3 -3
  36. package/lib/+shared/editor/core/helpers/rendering.helper.d.ts +3 -3
  37. package/lib/+shared/editor/custom-components/shared/abstract/base.component.d.ts +3 -1
  38. package/lib/+shared/editor/custom-components/shared/services/custom-content/custom-content.service.d.ts +1 -1
  39. package/lib/+shared/editor/custom-components/table/components/table-cell.component.d.ts +2 -2
  40. package/lib/+shared/editor/custom-components/table/components/table.component.d.ts +0 -2
  41. package/lib/+shared/editor/editor.component.d.ts +1 -5
  42. package/lib/+shared/editor/editor.module.d.ts +15 -16
  43. package/lib/+shared/editor/execution/models/general-properties.model.d.ts +1 -0
  44. package/lib/+shared/editor/execution/regulator.service.d.ts +2 -2
  45. package/lib/+shared/editor-title/editor-title.component.d.ts +24 -0
  46. package/lib/+shared/editor-toolbar/editor-toolbar.component.d.ts +31 -30
  47. package/lib/+shared/editor-toolbar/editor-toolbar.module.d.ts +19 -16
  48. package/lib/+shared/editor-toolbar/menu-dropdowns/menu-dropdowns.component.d.ts +73 -0
  49. package/lib/+shared/editor-toolbar/toolbar-actions/toolbar-actions.component.d.ts +49 -0
  50. package/lib/+shared/helpers/scaling.helper.d.ts +4 -0
  51. package/package.json +1 -1
  52. package/public-api.d.ts +1 -1
  53. package/src/_ngx-noder.theme.scss +10 -8
  54. package/src/lib/+shared/add-link-dialog/_add-link-dialog.theme.scss +3 -3
  55. package/src/lib/+shared/confirm-dialog/_theme.scss +6 -6
  56. package/src/lib/+shared/editor/_editor.theme.scss +84 -15
  57. package/src/lib/+shared/editor/_theme.scss +0 -2
  58. package/src/lib/+shared/editor-title/_editor-title.theme.scss +28 -0
  59. package/src/lib/+shared/editor-toolbar/_editor-toolbar.theme.scss +1 -24
  60. package/src/lib/+shared/editor-toolbar/_theme.scss +14 -2
  61. package/src/lib/+shared/editor-toolbar/font-size/_font-size.theme.scss +14 -0
  62. package/src/lib/+shared/editor-toolbar/font-style/_font-style.theme.scss +21 -0
  63. package/src/lib/+shared/editor-toolbar/format/_format.theme.scss +21 -0
  64. package/src/lib/+shared/editor-toolbar/menu-dropdowns/_menu-dropdowns.theme.scss +22 -0
  65. package/src/lib/+shared/editor-toolbar/numbering/_numbering.theme.scss +52 -11
  66. package/src/lib/+shared/editor-toolbar/toolbar-actions/_toolbar-actions.theme.scss +21 -0
  67. package/src/lib/+shared/editor-toolbar/undo-redo/_undo-redo.theme.scss +16 -0
  68. package/src/lib/+shared/insert-table/_insert-table.theme.scss +9 -6
  69. package/src/scss/_mixins.scss +2 -37
  70. package/esm2022/lib/+shared/editor/custom-components/external-element/element-toolbar/element-toolbar.component.mjs +0 -35
  71. package/esm2022/lib/+shared/editor-header/editor-header.component.mjs +0 -314
  72. package/lib/+shared/editor/custom-components/external-element/element-toolbar/element-toolbar.component.d.ts +0 -14
  73. package/lib/+shared/editor-header/editor-header.component.d.ts +0 -101
  74. package/src/lib/+shared/editor/custom-components/external-element/element-toolbar/_element-toolbar.theme.scss +0 -10
  75. package/src/lib/+shared/editor-header/_editor-header.theme.scss +0 -106
@@ -0,0 +1,126 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { DEFAULT_FONT_SIZE } from '../../editor/core/constants/editor.const';
3
+ import { ElementDataModel } from '../../editor/custom-components/external-element/models/element-data.model';
4
+ import { EXTERNAL_ELEMENT_SERVICE } from '../../editor/custom-components/external-element/external-elements.const';
5
+ import { NumberingTemplates } from '../constants/numbering-templates.const';
6
+ import { ParagraphStyleModel } from '../../../models/generated/paragraph-style.model';
7
+ import { TextStyleModel } from '../../../models/generated/text-style.model';
8
+ import { ToolbarStylesHelper } from '../helpers/toolbar-styles.helper';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "../../services/custom-icon.service";
11
+ import * as i2 from "@angular/common";
12
+ import * as i3 from "@angular/material/button";
13
+ import * as i4 from "@angular/material/icon";
14
+ import * as i5 from "../font/font.component";
15
+ import * as i6 from "../font-size/font-size.component";
16
+ import * as i7 from "../font-style/font-style.component";
17
+ import * as i8 from "../format/format.component";
18
+ import * as i9 from "../numbering/numbering.component";
19
+ import * as i10 from "../print/print.component";
20
+ import * as i11 from "../undo-redo/undo-redo.component";
21
+ export class ToolbarActionsComponent {
22
+ set historyInfo(value) {
23
+ this.canUndo = value.step !== -1;
24
+ this.canRedo = value.step < value.lastStep;
25
+ }
26
+ set styles(value) {
27
+ this._styles = value;
28
+ this.numberingType = ToolbarStylesHelper.getNumberingType(value.isBulletMarker);
29
+ this.numberingTemplateType = ToolbarStylesHelper.getNumberingTemplateType(value.numberingLevelsStyles);
30
+ }
31
+ get styles() {
32
+ return this._styles;
33
+ }
34
+ constructor(customIconService, injector) {
35
+ this.customIconService = customIconService;
36
+ this.injector = injector;
37
+ this.print = new EventEmitter();
38
+ this.redo = new EventEmitter();
39
+ this.undo = new EventEmitter();
40
+ this.changeParagraphStyle = new EventEmitter();
41
+ this.changeTextStyle = new EventEmitter();
42
+ this.setNumberingTemplateType = new EventEmitter();
43
+ this.removeNumberings = new EventEmitter();
44
+ this.createElement = new EventEmitter();
45
+ this.elements = this.injector.get(EXTERNAL_ELEMENT_SERVICE).elements;
46
+ this.customIconService.register();
47
+ }
48
+ onApplyFontFamily(font) {
49
+ this.checkFontLoadedAndApplyStyle(new TextStyleModel({ fontFamily: font }));
50
+ }
51
+ onApplyFontSize(size) {
52
+ this.checkFontLoadedAndApplyStyle(new TextStyleModel({ fontSize: size }));
53
+ }
54
+ onApplyBold(bold) {
55
+ this.checkFontLoadedAndApplyStyle(new TextStyleModel({ bold }));
56
+ }
57
+ onApplyUnderline(underline) {
58
+ this.changeTextStyle.emit(new TextStyleModel({ underline }));
59
+ }
60
+ onApplyItalic(italic) {
61
+ this.checkFontLoadedAndApplyStyle(new TextStyleModel({ italic }));
62
+ }
63
+ onApplyFontColor(color) {
64
+ this.changeTextStyle.emit(new TextStyleModel({ fontColor: color }));
65
+ }
66
+ onApplyHighlightColor(color) {
67
+ this.changeTextStyle.emit(new TextStyleModel({ highlightColor: color }));
68
+ }
69
+ onApplyAlignment(alignment) {
70
+ this.changeParagraphStyle.emit(new ParagraphStyleModel({ alignment }));
71
+ }
72
+ onSetNumberingTemplateType(templateType) {
73
+ const templateLevels = NumberingTemplates.find(x => x.templateType === templateType).levels;
74
+ this.setNumberingTemplateType.emit(templateLevels);
75
+ }
76
+ async onCreateElement(model) {
77
+ const data = await model.factoryMethod();
78
+ const element = new ElementDataModel(model.type, data.width, data.height, data.guid);
79
+ this.createElement.emit(element);
80
+ }
81
+ checkFontLoadedAndApplyStyle(style) {
82
+ const newStyles = { ...this.styles, ...style };
83
+ const italic = newStyles.italic ? 'italic ' : '';
84
+ const bold = newStyles.bold ? 'bold ' : '';
85
+ const fontStyles = `${italic}${bold}${newStyles.fontSize ?? DEFAULT_FONT_SIZE}pt ${newStyles.fontFamily}`;
86
+ if (document.fonts.check(fontStyles)) {
87
+ this.changeTextStyle.emit(style);
88
+ return;
89
+ }
90
+ document.fonts
91
+ .load(fontStyles)
92
+ .then(() => this.changeTextStyle.emit(style))
93
+ .catch(() => {
94
+ // continue regardless of error
95
+ });
96
+ }
97
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: ToolbarActionsComponent, deps: [{ token: i1.CustomIconService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component }); }
98
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: ToolbarActionsComponent, selector: "app-toolbar-actions", inputs: { isViewOnly: "isViewOnly", historyInfo: "historyInfo", styles: "styles" }, outputs: { print: "print", redo: "redo", undo: "undo", changeParagraphStyle: "changeParagraphStyle", changeTextStyle: "changeTextStyle", setNumberingTemplateType: "setNumberingTemplateType", removeNumberings: "removeNumberings", createElement: "createElement" }, ngImport: i0, template: "<app-undo-redo\n [canUndo]=\"canUndo\"\n [canRedo]=\"canRedo\"\n (undo)=\"undo.emit()\"\n (redo)=\"redo.emit()\" />\n<app-print (print)=\"print.emit()\" />\n<div class=\"separator\"></div>\n<app-font\n [isDisabled]=\"isViewOnly\"\n [styles]=\"styles\"\n (selectFont)=\"onApplyFontFamily($event)\" />\n<div class=\"separator\"></div>\n<app-font-size\n [isDisabled]=\"isViewOnly\"\n [fontSize]=\"styles.fontSize\"\n (selectFontSize)=\"onApplyFontSize($event)\" />\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)\" />\n<div class=\"separator\"></div>\n<div\n *ngIf=\"elements.length\"\n class=\"custom-elements\">\n <button\n *ngFor=\"let element of elements\"\n mat-button\n [disabled]=\"isViewOnly\"\n (click)=\"onCreateElement(element)\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"{{ element.icon }}\"></mat-icon>\n </button>\n <div class=\"separator\"></div>\n</div>\n<app-format\n [isDisabled]=\"isViewOnly\"\n [alignment]=\"styles.alignment\"\n (selectAlignment)=\"onApplyAlignment($event)\" />\n<div class=\"separator\"></div>\n<app-numbering\n [isDisabled]=\"isViewOnly\"\n [selectedNumberingType]=\"numberingType\"\n [selectedNumberingTemplate]=\"numberingTemplateType\"\n (selectNumberingTemplate)=\"onSetNumberingTemplateType($event)\"\n (removeNumberings)=\"removeNumberings.emit()\" />\n", styles: [":host::ng-deep mat-button-toggle,:host::ng-deep .mat-button-toggle-button{height:32px;width:32px;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}.custom-elements{display:flex;align-items:center;height:100%}.custom-elements .mdc-button{min-width:32px;min-height:32px;width:32px;height:32px;padding:0}.custom-elements .mdc-button>.mat-icon{margin-right:0;font-size:24px;height:24px;width:24px}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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: "component", type: i5.FontComponent, selector: "app-font", inputs: ["isDisabled", "styles"], outputs: ["selectFont"] }, { kind: "component", type: i6.FontSizeComponent, selector: "app-font-size", inputs: ["isDisabled", "fontSize"], outputs: ["selectFontSize"] }, { kind: "component", type: i7.FontStyleComponent, selector: "app-font-style", inputs: ["isDisabled", "bold", "italic", "underline", "fontColor", "highlightColor"], outputs: ["toggleBold", "toggleItalic", "toggleUnderline", "selectFontColor", "selectHighlightColor"] }, { kind: "component", type: i8.FormatComponent, selector: "app-format", inputs: ["isDisabled", "alignment"], outputs: ["selectAlignment"] }, { kind: "component", type: i9.NumberingComponent, selector: "app-numbering", inputs: ["isDisabled", "selectedNumberingType", "selectedNumberingTemplate"], outputs: ["selectNumberingTemplate", "removeNumberings"] }, { kind: "component", type: i10.PrintComponent, selector: "app-print", outputs: ["print"] }, { kind: "component", type: i11.UndoRedoComponent, selector: "app-undo-redo", inputs: ["canUndo", "canRedo"], outputs: ["undo", "redo"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
99
+ }
100
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: ToolbarActionsComponent, decorators: [{
101
+ type: Component,
102
+ args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'app-toolbar-actions', template: "<app-undo-redo\n [canUndo]=\"canUndo\"\n [canRedo]=\"canRedo\"\n (undo)=\"undo.emit()\"\n (redo)=\"redo.emit()\" />\n<app-print (print)=\"print.emit()\" />\n<div class=\"separator\"></div>\n<app-font\n [isDisabled]=\"isViewOnly\"\n [styles]=\"styles\"\n (selectFont)=\"onApplyFontFamily($event)\" />\n<div class=\"separator\"></div>\n<app-font-size\n [isDisabled]=\"isViewOnly\"\n [fontSize]=\"styles.fontSize\"\n (selectFontSize)=\"onApplyFontSize($event)\" />\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)\" />\n<div class=\"separator\"></div>\n<div\n *ngIf=\"elements.length\"\n class=\"custom-elements\">\n <button\n *ngFor=\"let element of elements\"\n mat-button\n [disabled]=\"isViewOnly\"\n (click)=\"onCreateElement(element)\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"{{ element.icon }}\"></mat-icon>\n </button>\n <div class=\"separator\"></div>\n</div>\n<app-format\n [isDisabled]=\"isViewOnly\"\n [alignment]=\"styles.alignment\"\n (selectAlignment)=\"onApplyAlignment($event)\" />\n<div class=\"separator\"></div>\n<app-numbering\n [isDisabled]=\"isViewOnly\"\n [selectedNumberingType]=\"numberingType\"\n [selectedNumberingTemplate]=\"numberingTemplateType\"\n (selectNumberingTemplate)=\"onSetNumberingTemplateType($event)\"\n (removeNumberings)=\"removeNumberings.emit()\" />\n", styles: [":host::ng-deep mat-button-toggle,:host::ng-deep .mat-button-toggle-button{height:32px;width:32px;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}.custom-elements{display:flex;align-items:center;height:100%}.custom-elements .mdc-button{min-width:32px;min-height:32px;width:32px;height:32px;padding:0}.custom-elements .mdc-button>.mat-icon{margin-right:0;font-size:24px;height:24px;width:24px}\n"] }]
103
+ }], ctorParameters: () => [{ type: i1.CustomIconService }, { type: i0.Injector }], propDecorators: { isViewOnly: [{
104
+ type: Input
105
+ }], historyInfo: [{
106
+ type: Input
107
+ }], styles: [{
108
+ type: Input
109
+ }], print: [{
110
+ type: Output
111
+ }], redo: [{
112
+ type: Output
113
+ }], undo: [{
114
+ type: Output
115
+ }], changeParagraphStyle: [{
116
+ type: Output
117
+ }], changeTextStyle: [{
118
+ type: Output
119
+ }], setNumberingTemplateType: [{
120
+ type: Output
121
+ }], removeNumberings: [{
122
+ type: Output
123
+ }], createElement: [{
124
+ type: Output
125
+ }] } });
126
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbar-actions.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-noder/src/lib/+shared/editor-toolbar/toolbar-actions/toolbar-actions.component.ts","../../../../../../../projects/ngx-noder/src/lib/+shared/editor-toolbar/toolbar-actions/toolbar-actions.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Injector, 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 { ElementDataModel } from '../../editor/custom-components/external-element/models/element-data.model';\nimport { EXTERNAL_ELEMENT_SERVICE } from '../../editor/custom-components/external-element/external-elements.const';\nimport { ExternalElementModel } from '../../editor/custom-components/external-element/models/external-element.model';\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-toolbar-actions',\n    templateUrl: 'toolbar-actions.component.html',\n    styleUrls: ['toolbar-actions.component.scss']\n})\nexport class ToolbarActionsComponent {\n    @Input() isViewOnly: boolean;\n\n    @Input()\n    set historyInfo(value: OperationsHistoryInfoModel) {\n        this.canUndo = value.step !== -1;\n        this.canRedo = value.step < value.lastStep;\n    }\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    @Output() print = new EventEmitter<void>();\n\n    @Output() redo = new EventEmitter<void>();\n\n    @Output() undo = new EventEmitter<void>();\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() createElement = new EventEmitter<ElementDataModel>();\n\n    canUndo: boolean;\n\n    canRedo: boolean;\n\n    numberingType: NumberingType | null;\n\n    numberingTemplateType: NumberingTemplateType | null;\n\n    elements: ExternalElementModel[];\n\n    constructor(private customIconService: CustomIconService, private injector: Injector) {\n        this.elements = this.injector.get(EXTERNAL_ELEMENT_SERVICE).elements;\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    async onCreateElement(model: ExternalElementModel) {\n        const data = await model.factoryMethod();\n        const element = new ElementDataModel(model.type, data.width, data.height, data.guid);\n        this.createElement.emit(element);\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","<app-undo-redo\n    [canUndo]=\"canUndo\"\n    [canRedo]=\"canRedo\"\n    (undo)=\"undo.emit()\"\n    (redo)=\"redo.emit()\" />\n<app-print (print)=\"print.emit()\" />\n<div class=\"separator\"></div>\n<app-font\n    [isDisabled]=\"isViewOnly\"\n    [styles]=\"styles\"\n    (selectFont)=\"onApplyFontFamily($event)\" />\n<div class=\"separator\"></div>\n<app-font-size\n    [isDisabled]=\"isViewOnly\"\n    [fontSize]=\"styles.fontSize\"\n    (selectFontSize)=\"onApplyFontSize($event)\" />\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)\" />\n<div class=\"separator\"></div>\n<div\n    *ngIf=\"elements.length\"\n    class=\"custom-elements\">\n    <button\n        *ngFor=\"let element of elements\"\n        mat-button\n        [disabled]=\"isViewOnly\"\n        (click)=\"onCreateElement(element)\">\n        <mat-icon\n            fontSet=\"nc-icon\"\n            fontIcon=\"{{ element.icon }}\"></mat-icon>\n    </button>\n    <div class=\"separator\"></div>\n</div>\n<app-format\n    [isDisabled]=\"isViewOnly\"\n    [alignment]=\"styles.alignment\"\n    (selectAlignment)=\"onApplyAlignment($event)\" />\n<div class=\"separator\"></div>\n<app-numbering\n    [isDisabled]=\"isViewOnly\"\n    [selectedNumberingType]=\"numberingType\"\n    [selectedNumberingTemplate]=\"numberingTemplateType\"\n    (selectNumberingTemplate)=\"onSetNumberingTemplateType($event)\"\n    (removeNumberings)=\"removeNumberings.emit()\" />\n"]}
@@ -10,11 +10,11 @@ export class UndoRedoComponent {
10
10
  this.redo = new EventEmitter();
11
11
  }
12
12
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: UndoRedoComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
13
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: UndoRedoComponent, selector: "app-undo-redo", inputs: { canUndo: "canUndo", canRedo: "canRedo" }, outputs: { undo: "undo", redo: "redo" }, ngImport: i0, template: "<button\n mat-button\n [disabled]=\"!canUndo\"\n (click)=\"undo.emit()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-undo\"></mat-icon>\n</button>\n<button\n mat-button\n [disabled]=\"!canRedo\"\n (click)=\"redo.emit()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-redo\"></mat-icon>\n</button>\n", styles: [":host{align-self:center}.mdc-button{min-width:28px;min-height:28px;height:28px;padding:0;margin:0 4px}.mdc-button mat-icon{font-size:24px;height:24px;width:24px;margin:0}\n"], dependencies: [{ kind: "component", type: i1.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
13
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: UndoRedoComponent, selector: "app-undo-redo", inputs: { canUndo: "canUndo", canRedo: "canRedo" }, outputs: { undo: "undo", redo: "redo" }, ngImport: i0, template: "<button\n mat-button\n [disabled]=\"!canUndo\"\n (click)=\"undo.emit()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-undo\"></mat-icon>\n</button>\n<button\n mat-button\n [disabled]=\"!canRedo\"\n (click)=\"redo.emit()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-redo\"></mat-icon>\n</button>\n", styles: [":host{display:flex;align-items:center}.mdc-button{min-width:28px;min-height:28px;height:28px;padding:0;margin:0 4px}.mdc-button mat-icon{font-size:24px;height:24px;width:24px;margin:0}\n"], dependencies: [{ kind: "component", type: i1.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
14
14
  }
15
15
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: UndoRedoComponent, decorators: [{
16
16
  type: Component,
17
- args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'app-undo-redo', template: "<button\n mat-button\n [disabled]=\"!canUndo\"\n (click)=\"undo.emit()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-undo\"></mat-icon>\n</button>\n<button\n mat-button\n [disabled]=\"!canRedo\"\n (click)=\"redo.emit()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-redo\"></mat-icon>\n</button>\n", styles: [":host{align-self:center}.mdc-button{min-width:28px;min-height:28px;height:28px;padding:0;margin:0 4px}.mdc-button mat-icon{font-size:24px;height:24px;width:24px;margin:0}\n"] }]
17
+ args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'app-undo-redo', template: "<button\n mat-button\n [disabled]=\"!canUndo\"\n (click)=\"undo.emit()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-undo\"></mat-icon>\n</button>\n<button\n mat-button\n [disabled]=\"!canRedo\"\n (click)=\"redo.emit()\">\n <mat-icon\n fontSet=\"nc-icon\"\n fontIcon=\"icon-redo\"></mat-icon>\n</button>\n", styles: [":host{display:flex;align-items:center}.mdc-button{min-width:28px;min-height:28px;height:28px;padding:0;margin:0 4px}.mdc-button mat-icon{font-size:24px;height:24px;width:24px;margin:0}\n"] }]
18
18
  }], propDecorators: { canUndo: [{
19
19
  type: Input
20
20
  }], canRedo: [{
@@ -0,0 +1,9 @@
1
+ export class ScalingHelper {
2
+ static getRatio(current, original) {
3
+ return parseFloat((current / original).toFixed(1));
4
+ }
5
+ static scale(initial, scale) {
6
+ return Math.round(initial * scale);
7
+ }
8
+ }
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NhbGluZy5oZWxwZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbm9kZXIvc3JjL2xpYi8rc2hhcmVkL2hlbHBlcnMvc2NhbGluZy5oZWxwZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLGFBQWE7SUFDdEIsTUFBTSxDQUFDLFFBQVEsQ0FBQyxPQUFlLEVBQUUsUUFBZ0I7UUFDN0MsT0FBTyxVQUFVLENBQUMsQ0FBQyxPQUFPLEdBQUcsUUFBUSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDdkQsQ0FBQztJQUVELE1BQU0sQ0FBQyxLQUFLLENBQUMsT0FBZSxFQUFFLEtBQWE7UUFDdkMsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUMsQ0FBQztJQUN2QyxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgU2NhbGluZ0hlbHBlciB7XG4gICAgc3RhdGljIGdldFJhdGlvKGN1cnJlbnQ6IG51bWJlciwgb3JpZ2luYWw6IG51bWJlcik6IG51bWJlciB7XG4gICAgICAgIHJldHVybiBwYXJzZUZsb2F0KChjdXJyZW50IC8gb3JpZ2luYWwpLnRvRml4ZWQoMSkpO1xuICAgIH1cblxuICAgIHN0YXRpYyBzY2FsZShpbml0aWFsOiBudW1iZXIsIHNjYWxlOiBudW1iZXIpOiBudW1iZXIge1xuICAgICAgICByZXR1cm4gTWF0aC5yb3VuZChpbml0aWFsICogc2NhbGUpO1xuICAgIH1cbn1cbiJdfQ==
@@ -20,7 +20,7 @@ export * from './lib/+shared/editor/operations/enums/command-type.enum';
20
20
  export * from './lib/+shared/editor/store/editor.actions';
21
21
  export * from './lib/+shared/editor/editor.component';
22
22
  export * from './lib/+shared/editor/editor.module';
23
- export * from './lib/+shared/editor-header/editor-header.component';
23
+ export * from './lib/+shared/editor-title/editor-title.component';
24
24
  export * from './lib/+shared/editor-search/editor-search-dialog.component';
25
25
  export * from './lib/+shared/editor-toolbar/enums/alignment.enum';
26
26
  export * from './lib/+shared/editor-toolbar/editor-toolbar.component';
@@ -43,4 +43,4 @@ export * from './lib/models/generated/operation.model';
43
43
  export * from './lib/models/generated/paragraph-style.model';
44
44
  export * from './lib/models/generated/revision.model';
45
45
  export * from './lib/models/generated/text-style.model';
46
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25neC1ub2Rlci9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsK0NBQStDLENBQUM7QUFFOUQsY0FBYyx5REFBeUQsQ0FBQztBQUN4RSxjQUFjLGtEQUFrRCxDQUFDO0FBRWpFLGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyxnREFBZ0QsQ0FBQztBQUUvRCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsdURBQXVELENBQUM7QUFFdEUsY0FBYywrREFBK0QsQ0FBQztBQUU5RSxjQUFjLG1GQUFtRixDQUFDO0FBQ2xHLGNBQWMsdUZBQXVGLENBQUM7QUFDdEcsY0FBYyw0RUFBNEUsQ0FBQztBQUMzRixjQUFjLGtGQUFrRixDQUFDO0FBQ2pHLGNBQWMsb0ZBQW9GLENBQUM7QUFFbkcsY0FBYyx5RUFBeUUsQ0FBQztBQUV4RixjQUFjLHVFQUF1RSxDQUFDO0FBRXRGLGNBQWMsaURBQWlELENBQUM7QUFFaEUsY0FBYyxzRUFBc0UsQ0FBQztBQUVyRixjQUFjLHlEQUF5RCxDQUFDO0FBRXhFLGNBQWMsMkNBQTJDLENBQUM7QUFFMUQsY0FBYyx1Q0FBdUMsQ0FBQztBQUV0RCxjQUFjLG9DQUFvQyxDQUFDO0FBRW5ELGNBQWMscURBQXFELENBQUM7QUFFcEUsY0FBYyw0REFBNEQsQ0FBQztBQUUzRSxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsdURBQXVELENBQUM7QUFDdEUsY0FBYyxvREFBb0QsQ0FBQztBQUVuRSxjQUFjLCtCQUErQixDQUFDO0FBRTlDLGNBQWMsdUNBQXVDLENBQUM7QUFFdEQsY0FBYyx1REFBdUQsQ0FBQztBQUN0RSxjQUFjLHlEQUF5RCxDQUFDO0FBRXhFLGNBQWMseUNBQXlDLENBQUM7QUFFeEQsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMsMENBQTBDLENBQUM7QUFDekQsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLHFEQUFxRCxDQUFDO0FBQ3BFLGNBQWMsOENBQThDLENBQUM7QUFDN0QsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyx5Q0FBeUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliLytzaGFyZWQvY29uc3RhbnRzL2RlZmF1bHQtZmlsZS1uYW1lLmNvbnN0JztcbmV4cG9ydCAqIGZyb20gJy4vbGliLytzaGFyZWQvY29uc3RhbnRzL3BhZ2luYXRvci1zaXplcy5jb25zdCc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliLytzaGFyZWQvZWRpdG9yL2NvcmUvY29uc3RhbnRzL2RvY3VtZW50LWluZm8uY29uc3QnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvK3NoYXJlZC9lZGl0b3IvY29yZS9jb25zdGFudHMvZWRpdG9yLmNvbnN0JztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvK3NoYXJlZC9lZGl0b3IvY29yZS9lbnVtcy9icmVhay10eXBlcy5lbnVtJztcbmV4cG9ydCAqIGZyb20gJy4vbGliLytzaGFyZWQvZWRpdG9yL2NvcmUvZW51bXMvcGFnZS10eXBlLmVudW0nO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VkaXRvci9jb3JlL2hlbHBlcnMvZG9tLmhlbHBlcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VkaXRvci9jb3JlL2hlbHBlcnMvZm9ybWF0LXN0eWxlLmhlbHBlcic7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliLytzaGFyZWQvZWRpdG9yL2NvcmUvaW50ZXJmYWNlcy90b29sYmFyLXN0eWxlcy5pbnRlcmZhY2UnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VkaXRvci9jdXN0b20tY29tcG9uZW50cy9leHRlcm5hbC1lbGVtZW50L21vZGVscy9lbGVtZW50LWRhdGEubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvK3NoYXJlZC9lZGl0b3IvY3VzdG9tLWNvbXBvbmVudHMvZXh0ZXJuYWwtZWxlbWVudC9tb2RlbHMvZXh0ZXJuYWwtZWxlbWVudC5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VkaXRvci9jdXN0b20tY29tcG9uZW50cy9leHRlcm5hbC1lbGVtZW50L2V4dGVybmFsLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VkaXRvci9jdXN0b20tY29tcG9uZW50cy9leHRlcm5hbC1lbGVtZW50L2V4dGVybmFsLWVsZW1lbnQuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VkaXRvci9jdXN0b20tY29tcG9uZW50cy9leHRlcm5hbC1lbGVtZW50L2V4dGVybmFsLXNpZGVuYXYuaW50ZXJmYWNlJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvK3NoYXJlZC9lZGl0b3IvY3VzdG9tLWNvbXBvbmVudHMvaW1hZ2Uvc2VydmljZXMvaW1hZ2UtYXBpLnNlcnZpY2UnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VkaXRvci9jdXN0b20tY29tcG9uZW50cy9zaGFyZWQvYWJzdHJhY3QvYmFzZS5jb21wb25lbnQnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VkaXRvci9pbnRlcmFjdGlvbi9lZGl0b3Iuc2VydmljZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliLytzaGFyZWQvZWRpdG9yL29wZXJhdGlvbi1oaXN0b3J5L29wZXJhdGlvbnMtaGlzdG9yeS1pbmZvLm1vZGVsJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvK3NoYXJlZC9lZGl0b3Ivb3BlcmF0aW9ucy9lbnVtcy9jb21tYW5kLXR5cGUuZW51bSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliLytzaGFyZWQvZWRpdG9yL3N0b3JlL2VkaXRvci5hY3Rpb25zJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvK3NoYXJlZC9lZGl0b3IvZWRpdG9yLmNvbXBvbmVudCc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliLytzaGFyZWQvZWRpdG9yL2VkaXRvci5tb2R1bGUnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VkaXRvci1oZWFkZXIvZWRpdG9yLWhlYWRlci5jb21wb25lbnQnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VkaXRvci1zZWFyY2gvZWRpdG9yLXNlYXJjaC1kaWFsb2cuY29tcG9uZW50JztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvK3NoYXJlZC9lZGl0b3ItdG9vbGJhci9lbnVtcy9hbGlnbm1lbnQuZW51bSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VkaXRvci10b29sYmFyL2VkaXRvci10b29sYmFyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VkaXRvci10b29sYmFyL2VkaXRvci10b29sYmFyLm1vZHVsZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliLytzaGFyZWQvZW51bXMvbW9kZS5lbnVtJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvK3NoYXJlZC9oZWxwZXJzL3JldmlzaW9uLmhlbHBlcic7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliLytzaGFyZWQvY29uZmlybS1kaWFsb2cvY29uZmlybS1kaWFsb2cuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliLytzaGFyZWQvYWRkLWxpbmstZGlhbG9nL2FkZC1saW5rLWRpYWxvZy5jb21wb25lbnQnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL3NlcnZpY2VzL2NvbW1hbmRzLnNlcnZpY2UnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RlbHMvZ2VuZXJhdGVkL2NvbW1hbmQubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL2dlbmVyYXRlZC9kb2N1bWVudC1uYW1lLm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9nZW5lcmF0ZWQvZG9jdW1lbnQubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL2dlbmVyYXRlZC9kb2N4Lm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9nZW5lcmF0ZWQvZWxlbWVudC5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RlbHMvZ2VuZXJhdGVkL2ZpbGUtc291cmNlLm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9nZW5lcmF0ZWQvaW1hZ2UtZGF0YS5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RlbHMvZ2VuZXJhdGVkL2xhc3QtZG9jdW1lbnQtcmV2aXNpb24ubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL2dlbmVyYXRlZC9udW1iZXJpbmctbGV2ZWwubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL2dlbmVyYXRlZC9vcGVyYXRpb24ubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL2dlbmVyYXRlZC9wYXJhZ3JhcGgtc3R5bGUubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL2dlbmVyYXRlZC9yZXZpc2lvbi5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RlbHMvZ2VuZXJhdGVkL3RleHQtc3R5bGUubW9kZWwnO1xuIl19
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25neC1ub2Rlci9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsK0NBQStDLENBQUM7QUFFOUQsY0FBYyx5REFBeUQsQ0FBQztBQUN4RSxjQUFjLGtEQUFrRCxDQUFDO0FBRWpFLGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyxnREFBZ0QsQ0FBQztBQUUvRCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsdURBQXVELENBQUM7QUFFdEUsY0FBYywrREFBK0QsQ0FBQztBQUU5RSxjQUFjLG1GQUFtRixDQUFDO0FBQ2xHLGNBQWMsdUZBQXVGLENBQUM7QUFDdEcsY0FBYyw0RUFBNEUsQ0FBQztBQUMzRixjQUFjLGtGQUFrRixDQUFDO0FBQ2pHLGNBQWMsb0ZBQW9GLENBQUM7QUFFbkcsY0FBYyx5RUFBeUUsQ0FBQztBQUV4RixjQUFjLHVFQUF1RSxDQUFDO0FBRXRGLGNBQWMsaURBQWlELENBQUM7QUFFaEUsY0FBYyxzRUFBc0UsQ0FBQztBQUVyRixjQUFjLHlEQUF5RCxDQUFDO0FBRXhFLGNBQWMsMkNBQTJDLENBQUM7QUFFMUQsY0FBYyx1Q0FBdUMsQ0FBQztBQUV0RCxjQUFjLG9DQUFvQyxDQUFDO0FBRW5ELGNBQWMsbURBQW1ELENBQUM7QUFFbEUsY0FBYyw0REFBNEQsQ0FBQztBQUUzRSxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsdURBQXVELENBQUM7QUFDdEUsY0FBYyxvREFBb0QsQ0FBQztBQUVuRSxjQUFjLCtCQUErQixDQUFDO0FBRTlDLGNBQWMsdUNBQXVDLENBQUM7QUFFdEQsY0FBYyx1REFBdUQsQ0FBQztBQUN0RSxjQUFjLHlEQUF5RCxDQUFDO0FBRXhFLGNBQWMseUNBQXlDLENBQUM7QUFFeEQsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMsMENBQTBDLENBQUM7QUFDekQsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLHFEQUFxRCxDQUFDO0FBQ3BFLGNBQWMsOENBQThDLENBQUM7QUFDN0QsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyx5Q0FBeUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliLytzaGFyZWQvY29uc3RhbnRzL2RlZmF1bHQtZmlsZS1uYW1lLmNvbnN0JztcbmV4cG9ydCAqIGZyb20gJy4vbGliLytzaGFyZWQvY29uc3RhbnRzL3BhZ2luYXRvci1zaXplcy5jb25zdCc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliLytzaGFyZWQvZWRpdG9yL2NvcmUvY29uc3RhbnRzL2RvY3VtZW50LWluZm8uY29uc3QnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvK3NoYXJlZC9lZGl0b3IvY29yZS9jb25zdGFudHMvZWRpdG9yLmNvbnN0JztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvK3NoYXJlZC9lZGl0b3IvY29yZS9lbnVtcy9icmVhay10eXBlcy5lbnVtJztcbmV4cG9ydCAqIGZyb20gJy4vbGliLytzaGFyZWQvZWRpdG9yL2NvcmUvZW51bXMvcGFnZS10eXBlLmVudW0nO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VkaXRvci9jb3JlL2hlbHBlcnMvZG9tLmhlbHBlcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VkaXRvci9jb3JlL2hlbHBlcnMvZm9ybWF0LXN0eWxlLmhlbHBlcic7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliLytzaGFyZWQvZWRpdG9yL2NvcmUvaW50ZXJmYWNlcy90b29sYmFyLXN0eWxlcy5pbnRlcmZhY2UnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VkaXRvci9jdXN0b20tY29tcG9uZW50cy9leHRlcm5hbC1lbGVtZW50L21vZGVscy9lbGVtZW50LWRhdGEubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvK3NoYXJlZC9lZGl0b3IvY3VzdG9tLWNvbXBvbmVudHMvZXh0ZXJuYWwtZWxlbWVudC9tb2RlbHMvZXh0ZXJuYWwtZWxlbWVudC5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VkaXRvci9jdXN0b20tY29tcG9uZW50cy9leHRlcm5hbC1lbGVtZW50L2V4dGVybmFsLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VkaXRvci9jdXN0b20tY29tcG9uZW50cy9leHRlcm5hbC1lbGVtZW50L2V4dGVybmFsLWVsZW1lbnQuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VkaXRvci9jdXN0b20tY29tcG9uZW50cy9leHRlcm5hbC1lbGVtZW50L2V4dGVybmFsLXNpZGVuYXYuaW50ZXJmYWNlJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvK3NoYXJlZC9lZGl0b3IvY3VzdG9tLWNvbXBvbmVudHMvaW1hZ2Uvc2VydmljZXMvaW1hZ2UtYXBpLnNlcnZpY2UnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VkaXRvci9jdXN0b20tY29tcG9uZW50cy9zaGFyZWQvYWJzdHJhY3QvYmFzZS5jb21wb25lbnQnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VkaXRvci9pbnRlcmFjdGlvbi9lZGl0b3Iuc2VydmljZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliLytzaGFyZWQvZWRpdG9yL29wZXJhdGlvbi1oaXN0b3J5L29wZXJhdGlvbnMtaGlzdG9yeS1pbmZvLm1vZGVsJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvK3NoYXJlZC9lZGl0b3Ivb3BlcmF0aW9ucy9lbnVtcy9jb21tYW5kLXR5cGUuZW51bSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliLytzaGFyZWQvZWRpdG9yL3N0b3JlL2VkaXRvci5hY3Rpb25zJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvK3NoYXJlZC9lZGl0b3IvZWRpdG9yLmNvbXBvbmVudCc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliLytzaGFyZWQvZWRpdG9yL2VkaXRvci5tb2R1bGUnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VkaXRvci10aXRsZS9lZGl0b3ItdGl0bGUuY29tcG9uZW50JztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvK3NoYXJlZC9lZGl0b3Itc2VhcmNoL2VkaXRvci1zZWFyY2gtZGlhbG9nLmNvbXBvbmVudCc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliLytzaGFyZWQvZWRpdG9yLXRvb2xiYXIvZW51bXMvYWxpZ25tZW50LmVudW0nO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvK3NoYXJlZC9lZGl0b3ItdG9vbGJhci9lZGl0b3ItdG9vbGJhci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvK3NoYXJlZC9lZGl0b3ItdG9vbGJhci9lZGl0b3ItdG9vbGJhci5tb2R1bGUnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2VudW1zL21vZGUuZW51bSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliLytzaGFyZWQvaGVscGVycy9yZXZpc2lvbi5oZWxwZXInO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2NvbmZpcm0tZGlhbG9nL2NvbmZpcm0tZGlhbG9nLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi8rc2hhcmVkL2FkZC1saW5rLWRpYWxvZy9hZGQtbGluay1kaWFsb2cuY29tcG9uZW50JztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvK3NoYXJlZC9zZXJ2aWNlcy9jb21tYW5kcy5zZXJ2aWNlJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL2dlbmVyYXRlZC9jb21tYW5kLm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9nZW5lcmF0ZWQvZG9jdW1lbnQtbmFtZS5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RlbHMvZ2VuZXJhdGVkL2RvY3VtZW50Lm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9nZW5lcmF0ZWQvZG9jeC5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RlbHMvZ2VuZXJhdGVkL2VsZW1lbnQubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL2dlbmVyYXRlZC9maWxlLXNvdXJjZS5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RlbHMvZ2VuZXJhdGVkL2ltYWdlLWRhdGEubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL2dlbmVyYXRlZC9sYXN0LWRvY3VtZW50LXJldmlzaW9uLm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9nZW5lcmF0ZWQvbnVtYmVyaW5nLWxldmVsLm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9nZW5lcmF0ZWQvb3BlcmF0aW9uLm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9nZW5lcmF0ZWQvcGFyYWdyYXBoLXN0eWxlLm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9nZW5lcmF0ZWQvcmV2aXNpb24ubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL2dlbmVyYXRlZC90ZXh0LXN0eWxlLm1vZGVsJztcbiJdfQ==