@firestitch/content 12.2.2 → 12.2.3

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 (34) hide show
  1. package/app/interfaces/content-config.d.ts +5 -5
  2. package/app/interfaces/content-page.d.ts +1 -0
  3. package/app/interfaces/content-style.d.ts +4 -0
  4. package/app/interfaces/index.d.ts +2 -1
  5. package/app/modules/content/components/content/content.component.d.ts +7 -3
  6. package/app/modules/content/components/content-renderer/content-renderer.component.d.ts +11 -9
  7. package/app/modules/content-layouts/components/content-layouts/content-layouts.component.d.ts +2 -1
  8. package/app/modules/content-pages/components/content-pages/content-pages.component.d.ts +2 -0
  9. package/app/modules/content-style/components/content-style/content-style.component.d.ts +27 -0
  10. package/app/modules/content-style/components/content-style/index.d.ts +1 -0
  11. package/app/modules/content-style/fs-content-style.module.d.ts +14 -0
  12. package/app/modules/editor/components/editor/editor.component.d.ts +24 -22
  13. package/app/modules/editor/fs-content-editor.module.d.ts +8 -5
  14. package/bundles/firestitch-content.umd.js +620 -523
  15. package/bundles/firestitch-content.umd.js.map +1 -1
  16. package/esm2015/app/interfaces/content-config.js +1 -1
  17. package/esm2015/app/interfaces/content-page.js +1 -1
  18. package/esm2015/app/interfaces/content-style.js +2 -0
  19. package/esm2015/app/interfaces/index.js +3 -2
  20. package/esm2015/app/modules/content/components/content/content.component.js +35 -20
  21. package/esm2015/app/modules/content/components/content-renderer/content-renderer.component.js +21 -19
  22. package/esm2015/app/modules/content-layouts/components/content-layouts/content-layouts.component.js +11 -8
  23. package/esm2015/app/modules/content-pages/components/content-pages/content-pages.component.js +16 -11
  24. package/esm2015/app/modules/content-pages/fs-content-pages.module.js +1 -1
  25. package/esm2015/app/modules/content-style/components/content-style/content-style.component.js +71 -0
  26. package/esm2015/app/modules/content-style/components/content-style/index.js +2 -0
  27. package/esm2015/app/modules/content-style/fs-content-style.module.js +50 -0
  28. package/esm2015/app/modules/editor/components/editor/editor.component.js +76 -116
  29. package/esm2015/app/modules/editor/fs-content-editor.module.js +19 -7
  30. package/esm2015/public_api.js +5 -3
  31. package/fesm2015/firestitch-content.js +446 -353
  32. package/fesm2015/firestitch-content.js.map +1 -1
  33. package/package.json +6 -5
  34. package/public_api.d.ts +5 -3
@@ -1,137 +1,115 @@
1
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, Inject, ViewChild, } from '@angular/core';
2
- import { MAT_DIALOG_DATA, MatDialog, MatDialogRef } from '@angular/material/dialog';
3
- import { FsFormDirective } from '@firestitch/form';
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, } from '@angular/core';
2
+ import { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';
4
3
  import { FsMessage } from '@firestitch/message';
5
- import { FsTextEditorComponent } from '@firestitch/text-editor';
6
- import { Subject, fromEvent } from 'rxjs';
7
- import { finalize, take, takeUntil, tap } from 'rxjs/operators';
8
- import { ContentPageComponent } from '../../../content-pages/components/content-page';
4
+ import { Subject } from 'rxjs';
5
+ import { takeUntil, tap } from 'rxjs/operators';
9
6
  import * as i0 from "@angular/core";
10
7
  import * as i1 from "@angular/material/dialog";
11
8
  import * as i2 from "@firestitch/message";
12
9
  import * as i3 from "@firestitch/dialog";
13
10
  import * as i4 from "@angular/material/button";
14
11
  import * as i5 from "@angular/material/icon";
15
- import * as i6 from "@firestitch/label";
16
- import * as i7 from "@firestitch/text-editor";
17
- import * as i8 from "@firestitch/form";
18
- import * as i9 from "@angular/material/button-toggle";
19
- import * as i10 from "@angular/forms";
20
- import * as i11 from "@angular/common";
12
+ import * as i6 from "angular-split";
13
+ import * as i7 from "@firestitch/label";
14
+ import * as i8 from "@firestitch/text-editor";
15
+ import * as i9 from "@firestitch/form";
16
+ import * as i10 from "@angular/material/button-toggle";
17
+ import * as i11 from "@angular/forms";
18
+ import * as i12 from "@firestitch/common";
19
+ import * as i13 from "@firestitch/skeleton";
21
20
  export class EditorComponent {
22
- constructor(_data, _dialogRef, _dialog, _message, _cdRef) {
21
+ constructor(_data, _dialogRef, _message, _cdRef) {
23
22
  this._data = _data;
24
23
  this._dialogRef = _dialogRef;
25
- this._dialog = _dialog;
26
24
  this._message = _message;
27
25
  this._cdRef = _cdRef;
28
26
  this.resizing = false;
29
- this.editors = { content: true, styles: true };
30
- this._destroy$ = new Subject();
31
- this.save = () => {
32
- return this._save({
33
- id: this.contentPage.id,
34
- styles: this.contentPage.styles,
35
- content: this.contentPage.content,
36
- })
37
- .pipe(tap((contentPage) => {
38
- this.contentPage = Object.assign(Object.assign({}, this.contentPage), contentPage);
39
- this._cdRef.markForCheck();
40
- this._message.success('Saved Changes');
41
- }));
27
+ this.editors = {
28
+ html: true,
29
+ scss: true,
30
+ js: false,
31
+ globalScss: false,
42
32
  };
33
+ this._destroy$ = new Subject();
43
34
  }
44
35
  ngOnInit() {
45
- this.stylesConfig = {
46
- tabSize: 2,
47
- language: 'scss',
48
- height: '100%',
49
- };
50
- this.contentConfig = {
51
- tabSize: 2,
52
- language: 'html',
53
- height: '100%',
54
- };
36
+ this._dialogRef.addPanelClass('fs-content-editor-overlay-pane');
55
37
  this.title = this._data.title;
56
38
  this.contentPage = this._data.contentPage;
39
+ this._config = this._data.contentConfig;
57
40
  this._save = this._data.save;
58
- this._initSeparator();
41
+ this.initTextEditors();
42
+ this.initGlobalContentStyle();
59
43
  }
60
44
  editorToggleChange(event) {
61
45
  this.editors[event.value] = !this.editors[event.value];
62
- this.updateEditorLayouts();
63
- }
64
- updateEditorLayouts() {
65
- setTimeout(() => {
66
- if (this.editors.content) {
67
- this.contentEditor.updateLayout();
68
- }
69
- if (this.editors.styles) {
70
- this.styleEditor.updateLayout();
71
- }
72
- });
73
46
  }
74
47
  ngOnDestroy() {
75
48
  this._destroy$.next();
76
49
  this._destroy$.complete();
77
50
  }
78
- stylesChanged() {
79
- this.form.triggerSubmit();
51
+ globalScssChange() {
52
+ this._config.saveContentStyle(this.contentStyle)
53
+ .subscribe((contentStyle) => {
54
+ this.contentStyle = contentStyle;
55
+ this._message.success('Saved Changes');
56
+ this._cdRef.markForCheck();
57
+ });
58
+ }
59
+ initTextEditors() {
60
+ this.scssConfig = {
61
+ tabSize: 2,
62
+ language: 'scss',
63
+ height: '100%',
64
+ };
65
+ this.jsConfig = {
66
+ tabSize: 2,
67
+ language: 'js',
68
+ height: '100%',
69
+ };
70
+ this.htmlConfig = {
71
+ tabSize: 2,
72
+ language: 'html',
73
+ height: '100%',
74
+ };
75
+ this.globalScssConfig = {
76
+ tabSize: 2,
77
+ language: 'scss',
78
+ height: '100%',
79
+ };
80
80
  }
81
- contentChanged() {
82
- this.form.triggerSubmit();
81
+ initGlobalContentStyle() {
82
+ this._config.loadContentStyle()
83
+ .subscribe((contentStyle) => {
84
+ this.contentStyle = contentStyle;
85
+ this._cdRef.markForCheck();
86
+ });
83
87
  }
84
- openSettings() {
85
- this._dialog.open(ContentPageComponent, {
86
- data: {
87
- contentPage: this.contentPage,
88
- },
88
+ saveContentPage() {
89
+ this._save({
90
+ id: this.contentPage.id,
91
+ styles: this.contentPage.styles,
92
+ content: this.contentPage.content,
93
+ js: this.contentPage.js,
89
94
  })
90
- .afterClosed()
91
- .pipe(takeUntil(this._destroy$))
92
- .subscribe((contentPage) => {
95
+ .pipe(tap((contentPage) => {
93
96
  this.contentPage = Object.assign(Object.assign({}, this.contentPage), contentPage);
94
97
  this._cdRef.markForCheck();
95
- });
98
+ this._message.success('Saved Changes');
99
+ }))
100
+ .subscribe();
96
101
  }
97
- _initSeparator() {
98
- fromEvent(this.separator.nativeElement, 'mousedown')
102
+ openSettings() {
103
+ this._data.openSettings(this.contentPage)
99
104
  .pipe(takeUntil(this._destroy$))
100
- .subscribe((e) => {
101
- this._moveSeparator(e);
102
- });
103
- }
104
- _moveSeparator(separatorEvent) {
105
- let mouseDown = {
106
- clientX: separatorEvent.clientX,
107
- clientY: separatorEvent.clientY,
108
- offsetLeft: Number(this.separator.nativeElement.offsetLeft),
109
- offsetTop: Number(this.separator.nativeElement.offsetTop),
110
- firstWidth: Number(this.contentContainer.nativeElement.offsetWidth),
111
- secondWidth: Number(this.styleContainer.nativeElement.offsetWidth),
112
- };
113
- this.resizing = true;
114
- this._cdRef.markForCheck();
115
- fromEvent(document, 'mousemove')
116
- .pipe(finalize(() => {
117
- mouseDown = null;
118
- this.resizing = false;
105
+ .subscribe((contentPage) => {
106
+ this.contentPage = Object.assign(Object.assign({}, this.contentPage), contentPage);
119
107
  this._cdRef.markForCheck();
120
- this.updateEditorLayouts();
121
- }), takeUntil(fromEvent(this.separator.nativeElement, 'mouseup')
122
- .pipe(take(1), takeUntil(this._destroy$))), takeUntil(this._destroy$))
123
- .subscribe((e) => {
124
- const delta = { x: e.clientX - mouseDown.clientX,
125
- y: e.clientY - mouseDown.clientY };
126
- delta.x = Math.min(Math.max(delta.x, -mouseDown.firstWidth), mouseDown.secondWidth);
127
- this.separator.nativeElement.style.left = `${mouseDown.offsetLeft + delta.x}px`;
128
- this.contentContainer.nativeElement.style.width = `${mouseDown.firstWidth + delta.x}px`;
129
- this.styleContainer.nativeElement.style.width = `${mouseDown.secondWidth - delta.x}px`;
130
108
  });
131
109
  }
132
110
  }
133
- EditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: EditorComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }, { token: i1.MatDialog }, { token: i2.FsMessage }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
134
- EditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: EditorComponent, selector: "ng-component", viewQueries: [{ propertyName: "form", first: true, predicate: FsFormDirective, descendants: true }, { propertyName: "styleEditor", first: true, predicate: ["styleEditor"], descendants: true }, { propertyName: "contentEditor", first: true, predicate: ["contentEditor"], descendants: true }, { propertyName: "separator", first: true, predicate: ["separator"], descendants: true, read: ElementRef, static: true }, { propertyName: "contentContainer", first: true, predicate: ["contentContainer"], descendants: true, read: ElementRef, static: true }, { propertyName: "styleContainer", first: true, predicate: ["styleContainer"], descendants: true, read: ElementRef, static: true }], ngImport: i0, template: "<form fsForm [submit]=\"save\">\n <fs-dialog>\n <h1 mat-dialog-title>\n <div class=\"title-container\">\n <div class=\"title\">\n {{title}}\n <div class=\"small\">{{contentPage.name}}</div> \n </div>\n <a\n (click)=\"openSettings()\"\n mat-icon-button>\n <mat-icon>settings</mat-icon>\n </a> \n </div>\n </h1>\n <div mat-dialog-content>\n <div class=\"container\">\n <div class=\"editors\" [ngClass]=\"{ resizing: resizing, 'separator-enabled': editors.styles && editors.content }\">\n <div #contentContainer class=\"editor editor-content\" [ngClass]=\"{ 'content-enabled': editors.content }\">\n <fs-label>HTML</fs-label>\n <div class=\"editor-container\">\n <fs-text-editor \n #contentEditor\n [(ngModel)]=\"contentPage.content\" \n (blur)=\"contentChanged()\"\n name=\"content\"\n [config]=\"contentConfig\">\n </fs-text-editor> \n </div>\n </div>\n <div \n #separator\n class=\"separator\">\n <mat-icon>drag_indicator</mat-icon>\n </div>\n <div \n #styleContainer \n class=\"editor editor-styles\" \n [ngClass]=\"{ 'styles-enabled': editors.styles }\"\n [style.width]=\"'600px'\">\n <fs-label>SCSS</fs-label>\n <div class=\"editor-container\">\n <fs-text-editor \n #styleEditor\n [(ngModel)]=\"contentPage.styles\" \n (blur)=\"stylesChanged()\"\n name=\"styles\"\n [config]=\"stylesConfig\">\n </fs-text-editor> \n </div>\n </div> \n </div>\n </div>\n </div>\n\n <div mat-dialog-actions>\n <fs-form-dialog-actions\n [save]=\"false\"\n [done]=\"true\">\n </fs-form-dialog-actions>\n <div class=\"toggles\">\n <mat-button-toggle-group multiple>\n <mat-button-toggle value=\"content\" [checked]=\"editors.content\" (change)=\"editorToggleChange($event)\">Content</mat-button-toggle>\n <mat-button-toggle value=\"styles\" [checked]=\"editors.styles\" (change)=\"editorToggleChange($event)\">Styles</mat-button-toggle>\n </mat-button-toggle-group> \n </div>\n </div>\n </fs-dialog>\n</form>\n\n", styles: ["form{display:block;height:100%}form fs-dialog{display:flex;flex-direction:column;height:100%}form ::ng-deep .mat-dialog-content{max-height:none;flex:1;overflow:hidden}.mat-dialog-actions fs-form-dialog-actions{width:auto}.mat-dialog-actions .toggles{display:flex;justify-content:flex-end;justify-self:baseline;flex:1}.container{height:100%;display:flex;flex-direction:column}.editors{width:5000px;max-width:100%;height:100%;display:flex;min-height:0}.editors:not(.separator-enabled) .separator{display:none}.editors:not(.separator-enabled) .editor{width:100%!important}.editors .separator{display:flex;align-items:center;justify-content:center;cursor:col-resize;background-color:#fff;width:40px;height:100%;-webkit-user-select:none;user-select:none;flex-shrink:0}.editors .editor{height:100%;display:flex;min-width:0;width:100%;flex-direction:column;flex-grow:1}.editors .editor.editor-styles:not(.styles-enabled),.editors .editor.editor-content:not(.content-enabled){display:none}.editors .editor .editor-container{height:100%;background:#1E1E1E;border-radius:5px}.editors .editor+.editor{margin-left:20px}.editors .editor fs-label{background-color:#fff;padding-bottom:5px}.title-container{display:flex;align-items:center}.title-container .title{flex:1}.title-container .title .small{line-height:normal}\n"], components: [{ type: i3.FsDialogComponent, selector: "fs-dialog", inputs: ["mobileMode", "mobileActionPlacement", "mobileWidth", "mode"] }, { type: i4.MatAnchor, selector: "a[mat-button], a[mat-raised-button], a[mat-icon-button], a[mat-fab], a[mat-mini-fab], a[mat-stroked-button], a[mat-flat-button]", inputs: ["disabled", "disableRipple", "color", "tabIndex"], exportAs: ["matButton", "matAnchor"] }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i6.FsLabelComponent, selector: "fs-label" }, { type: i7.FsTextEditorComponent, selector: "fs-text-editor", inputs: ["config", "scrollable"], outputs: ["ready", "blur"] }, { type: i8.FsFormDialogActionsComponent, selector: "fs-form-dialog-actions", inputs: ["save", "create", "close", "done", "closeData", "name"] }, { type: i9.MatButtonToggle, selector: "mat-button-toggle", inputs: ["disableRipple", "aria-labelledby", "tabIndex", "appearance", "checked", "disabled", "id", "name", "aria-label", "value"], outputs: ["change"], exportAs: ["matButtonToggle"] }], directives: [{ type: i10.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i10.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i10.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i8.FsFormDirective, selector: "[fsForm]", inputs: ["wrapperSelector", "messageSelector", "hintSelector", "labelSelector", "autocomplete", "shortcuts", "confirm", "confirmDialog", "confirmDrawer", "confirmBrowser", "confirmTabs", "dirtySubmitButton", "submit", "successDelay", "errorDelay", "tabGroup", "deactivationGuard"], outputs: ["fsForm", "invalid", "valid", "submitted", "reseted", "cleared"], exportAs: ["fsForm"] }, { type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i11.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i10.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i10.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i8.FsFormNoFsValidatorsDirective, selector: "[ngModel]:not([required]):not([fsFormRequired]):not([fsFormCompare]):not([fsFormDateRange]):not([fsFormEmail]):not([fsFormEmails]):not([fsFormFunction]):not([fsFormGreater]):not([fsFormInteger]):not([fsFormLesser]):not([fsFormMax]):not([fsFormMaxLength]):not([fsFormMin]):not([fsFormMinLength]):not([fsFormNumeric]):not([fsFormPattern]):not([fsFormPhone]):not([fsFormUrl]):not([validate])" }, { type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }, { type: i9.MatButtonToggleGroup, selector: "mat-button-toggle-group", inputs: ["appearance", "name", "vertical", "value", "multiple", "disabled"], outputs: ["valueChange", "change"], exportAs: ["matButtonToggleGroup"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
111
+ EditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: EditorComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }, { token: i2.FsMessage }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
112
+ EditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: EditorComponent, selector: "ng-component", ngImport: i0, template: "<fs-dialog>\n <h1 mat-dialog-title>\n <div class=\"title-container\">\n <div class=\"title\">\n {{title}}\n <div class=\"small\">{{contentPage.name}}</div> \n </div>\n <a\n (click)=\"openSettings()\"\n mat-icon-button>\n <mat-icon>settings</mat-icon>\n </a> \n </div>\n </h1>\n <div mat-dialog-content>\n <div class=\"container\">\n <as-split [unit]=\"'percent'\" [gutterSize]=\"25\"> \n <as-split-area [size]=\"70\" [visible]=\"editors.html\" [order]=\"1\">\n <div class=\"editor-container\">\n <fs-label>HTML</fs-label>\n <fs-text-editor \n [(ngModel)]=\"contentPage.content\" \n name=\"html\"\n [fsModelChangeOptions]=\"{ debounce: 300 }\"\n (fsModelChange)=\"saveContentPage()\"\n [config]=\"htmlConfig\">\n </fs-text-editor> \n </div>\n </as-split-area>\n <as-split-area [size]=\"30\" [visible]=\"editors.scss\" [order]=\"2\">\n <div class=\"editor-container\">\n <fs-label>SCSS</fs-label>\n <fs-text-editor \n [(ngModel)]=\"contentPage.styles\" \n name=\"scss\"\n [fsModelChangeOptions]=\"{ debounce: 300 }\"\n (fsModelChange)=\"saveContentPage()\"\n [config]=\"scssConfig\">\n </fs-text-editor> \n </div>\n </as-split-area>\n <as-split-area [size]=\"30\" [visible]=\"editors.js\" [order]=\"3\">\n <div class=\"editor-container\">\n <fs-label>JS</fs-label>\n <fs-text-editor \n [(ngModel)]=\"contentPage.js\" \n name=\"js\"\n [fsModelChangeOptions]=\"{ debounce: 300 }\"\n (fsModelChange)=\"saveContentPage()\"\n [config]=\"jsConfig\">\n </fs-text-editor> \n </div>\n </as-split-area>\n <as-split-area [size]=\"30\" [visible]=\"editors.globalScss\" [order]=\"4\">\n <div class=\"editor-container\">\n <fs-label>Global SCSS</fs-label>\n <ng-container *fsSkeleton=\"contentStyle\">\n <fs-text-editor \n [(ngModel)]=\"contentStyle.scss\" \n name=\"globalScss\"\n [fsModelChangeOptions]=\"{ debounce: 300 }\"\n (fsModelChange)=\"globalScssChange()\"\n [config]=\"globalScssConfig\">\n </fs-text-editor> \n </ng-container> \n </div>\n </as-split-area>\n </as-split>\n </div>\n </div>\n\n <div mat-dialog-actions>\n <fs-form-dialog-actions\n [save]=\"false\"\n [done]=\"true\">\n </fs-form-dialog-actions>\n <div class=\"toggles\">\n <mat-button-toggle-group multiple>\n <mat-button-toggle value=\"html\" [checked]=\"editors.html\" (change)=\"editorToggleChange($event)\">HTML</mat-button-toggle>\n <mat-button-toggle value=\"scss\" [checked]=\"editors.scss\" (change)=\"editorToggleChange($event)\">SCSS</mat-button-toggle>\n <mat-button-toggle value=\"js\" [checked]=\"editors.js\" (change)=\"editorToggleChange($event)\">JS</mat-button-toggle>\n <mat-button-toggle value=\"globalScss\" [checked]=\"editors.globalScss\" (change)=\"editorToggleChange($event)\">Global SCSS</mat-button-toggle>\n </mat-button-toggle-group> \n </div>\n </div>\n</fs-dialog>\n\n", styles: ["::ng-deep .fs-content-editor-overlay-pane .mat-dialog-container{border-radius:0}:host ::ng-deep .as-split-gutter{background-color:unset!important}fs-dialog{display:flex;height:100%;flex-direction:column}fs-dialog ::ng-deep .mat-dialog-content{max-height:none;flex:1;overflow:hidden}.mat-dialog-actions fs-form-dialog-actions{width:auto}.mat-dialog-actions .toggles{display:flex;justify-content:flex-end;justify-self:baseline;flex:1}.container{height:100%;display:flex;flex-direction:column}.editor-container{height:100%;border-radius:5px;display:flex;flex-direction:column}.editor-container fs-text-editor{flex:1}.title-container{display:flex;align-items:center}.title-container .title{flex:1}.title-container .title .small{line-height:normal}\n"], components: [{ type: i3.FsDialogComponent, selector: "fs-dialog", inputs: ["mobileMode", "mobileActionPlacement", "mobileWidth", "mode"] }, { type: i4.MatAnchor, selector: "a[mat-button], a[mat-raised-button], a[mat-icon-button], a[mat-fab], a[mat-mini-fab], a[mat-stroked-button], a[mat-flat-button]", inputs: ["disabled", "disableRipple", "color", "tabIndex"], exportAs: ["matButton", "matAnchor"] }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i6.SplitComponent, selector: "as-split", inputs: ["direction", "unit", "gutterSize", "gutterStep", "restrictMove", "useTransition", "disabled", "dir", "gutterDblClickDuration", "gutterClickDeltaPx", "gutterAriaLabel"], outputs: ["transitionEnd", "dragStart", "dragEnd", "gutterClick", "gutterDblClick"], exportAs: ["asSplit"] }, { type: i7.FsLabelComponent, selector: "fs-label" }, { type: i8.FsTextEditorComponent, selector: "fs-text-editor", inputs: ["config", "scrollable"], outputs: ["ready", "blur"] }, { type: i9.FsFormDialogActionsComponent, selector: "fs-form-dialog-actions", inputs: ["save", "create", "close", "done", "closeData", "name"] }, { type: i10.MatButtonToggle, selector: "mat-button-toggle", inputs: ["disableRipple", "aria-labelledby", "tabIndex", "appearance", "checked", "disabled", "id", "name", "aria-label", "value"], outputs: ["change"], exportAs: ["matButtonToggle"] }], directives: [{ type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i6.SplitAreaDirective, selector: "as-split-area, [as-split-area]", inputs: ["order", "size", "minSize", "maxSize", "lockSize", "visible"], exportAs: ["asSplitArea"] }, { type: i11.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i11.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i9.FsFormNoFsValidatorsDirective, selector: "[ngModel]:not([required]):not([fsFormRequired]):not([fsFormCompare]):not([fsFormDateRange]):not([fsFormEmail]):not([fsFormEmails]):not([fsFormFunction]):not([fsFormGreater]):not([fsFormInteger]):not([fsFormLesser]):not([fsFormMax]):not([fsFormMaxLength]):not([fsFormMin]):not([fsFormMinLength]):not([fsFormNumeric]):not([fsFormPattern]):not([fsFormPhone]):not([fsFormUrl]):not([validate])" }, { type: i12.FsModelChangeDirective, selector: "[fsModelChange]", inputs: ["fsModelChangeOptions"], outputs: ["fsModelChange"] }, { type: i13.FsSkeletonContentDirective, selector: "[fsSkeleton]", inputs: ["fsSkeleton", "fsSkeletonPattern"] }, { type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }, { type: i10.MatButtonToggleGroup, selector: "mat-button-toggle-group", inputs: ["appearance", "name", "vertical", "value", "multiple", "disabled"], outputs: ["valueChange", "change"], exportAs: ["matButtonToggleGroup"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
135
113
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: EditorComponent, decorators: [{
136
114
  type: Component,
137
115
  args: [{
@@ -142,23 +120,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
142
120
  }], ctorParameters: function () { return [{ type: undefined, decorators: [{
143
121
  type: Inject,
144
122
  args: [MAT_DIALOG_DATA]
145
- }] }, { type: i1.MatDialogRef }, { type: i1.MatDialog }, { type: i2.FsMessage }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { form: [{
146
- type: ViewChild,
147
- args: [FsFormDirective]
148
- }], styleEditor: [{
149
- type: ViewChild,
150
- args: ['styleEditor']
151
- }], contentEditor: [{
152
- type: ViewChild,
153
- args: ['contentEditor']
154
- }], separator: [{
155
- type: ViewChild,
156
- args: ['separator', { static: true, read: ElementRef }]
157
- }], contentContainer: [{
158
- type: ViewChild,
159
- args: ['contentContainer', { static: true, read: ElementRef }]
160
- }], styleContainer: [{
161
- type: ViewChild,
162
- args: ['styleContainer', { static: true, read: ElementRef }]
163
- }] } });
164
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.component.js","sourceRoot":"","sources":["../../../../../../../src/app/modules/editor/components/editor/editor.component.ts","../../../../../../../src/app/modules/editor/components/editor/editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Inject,\n  OnDestroy,\n  OnInit,\n  ViewChild,\n} from '@angular/core';\n\nimport { MatButtonToggleChange } from '@angular/material/button-toggle';\nimport { MAT_DIALOG_DATA, MatDialog, MatDialogRef } from '@angular/material/dialog';\n\nimport { FsFormDirective } from '@firestitch/form';\nimport { FsMessage } from '@firestitch/message';\nimport { FsTextEditorComponent, FsTextEditorConfig } from '@firestitch/text-editor';\n\nimport { Observable, Subject, fromEvent } from 'rxjs';\nimport { finalize, take, takeUntil, tap } from 'rxjs/operators';\n\n\nimport { ContentPageComponent } from '../../../content-pages/components/content-page';\n\n\n@Component({\n  templateUrl: './editor.component.html',\n  styleUrls: ['./editor.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class EditorComponent implements OnInit, OnDestroy {\n\n  @ViewChild(FsFormDirective)\n  public form: FsFormDirective;\n\n  @ViewChild('styleEditor')\n  public styleEditor: FsTextEditorComponent;\n\n  @ViewChild('contentEditor')\n  public contentEditor: FsTextEditorComponent;\n\n  @ViewChild('separator', { static: true, read: ElementRef })\n  public separator: ElementRef;\n\n  @ViewChild('contentContainer', { static: true, read: ElementRef })\n  public contentContainer: ElementRef;\n\n  @ViewChild('styleContainer', { static: true, read: ElementRef })\n  public styleContainer: ElementRef;\n\n  public contentPage: {\n    id?: number;\n    styles?: string;\n    content?: string;\n    name?: string;\n  };\n\n  public resizing = false;\n  public title;\n  public editors = { content: true, styles: true };\n  public stylesConfig: FsTextEditorConfig;\n  public contentConfig: FsTextEditorConfig;\n\n  private _destroy$ = new Subject<void>();\n  private _save: (data) => Observable<any>;\n\n  constructor(\n    @Inject(MAT_DIALOG_DATA) private _data: {\n      contentPage: any;\n      title: string;\n      save: (data) => Observable<any>;\n    },\n    private _dialogRef: MatDialogRef<EditorComponent>,\n    private _dialog: MatDialog,\n    private _message: FsMessage,\n    private _cdRef: ChangeDetectorRef,\n  ) {}\n\n  public ngOnInit(): void {\n    this.stylesConfig = {\n      tabSize: 2,\n      language: 'scss',\n      height: '100%',\n    };\n    this.contentConfig = {\n      tabSize: 2,\n      language: 'html',\n      height: '100%',\n    };\n    this.title = this._data.title;\n    this.contentPage = this._data.contentPage;\n    this._save = this._data.save;\n    this._initSeparator();\n  }\n\n  public editorToggleChange(event: MatButtonToggleChange): void {\n    this.editors[event.value] = !this.editors[event.value];\n    this.updateEditorLayouts();\n  }\n\n  public updateEditorLayouts(): void {\n    setTimeout(() => {\n      if(this.editors.content) {\n        this.contentEditor.updateLayout();\n      }\n\n      if(this.editors.styles) {\n        this.styleEditor.updateLayout();\n      }\n    });\n  }\n\n  public ngOnDestroy(): void {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  public stylesChanged() {\n    this.form.triggerSubmit();\n  }\n\n  public contentChanged() {\n    this.form.triggerSubmit();\n  }\n\n  public save = () => {\n    return this._save({\n      id: this.contentPage.id,\n      styles: this.contentPage.styles,\n      content: this.contentPage.content,\n    })\n      .pipe(\n        tap((contentPage) => {\n          this.contentPage = {\n            ...this.contentPage,\n            ...contentPage,\n          };\n          this._cdRef.markForCheck();\n          this._message.success('Saved Changes');\n        }),\n      );\n  };\n\n  public openSettings(): void {\n    this._dialog.open(ContentPageComponent, {\n      data: {\n        contentPage: this.contentPage,\n      },\n    })\n      .afterClosed()\n      .pipe(\n        takeUntil(this._destroy$),\n      )\n      .subscribe((contentPage) => {\n        this.contentPage = {\n          ...this.contentPage,\n          ...contentPage,\n        };\n        this._cdRef.markForCheck();\n      });\n  }\n\n\n  private _initSeparator(): void {\n    fromEvent(this.separator.nativeElement, 'mousedown')\n      .pipe(\n        takeUntil(this._destroy$),\n      )\n      .subscribe((e) => {\n        this._moveSeparator(e);\n      });\n  }\n\n  private _moveSeparator(separatorEvent): void {\n    let mouseDown = {\n      clientX: separatorEvent.clientX,\n      clientY: separatorEvent.clientY,\n      offsetLeft:  Number(this.separator.nativeElement.offsetLeft),\n      offsetTop:   Number(this.separator.nativeElement.offsetTop),\n      firstWidth:  Number(this.contentContainer.nativeElement.offsetWidth),\n      secondWidth: Number(this.styleContainer.nativeElement.offsetWidth),\n    };\n\n    this.resizing = true;\n    this._cdRef.markForCheck();\n\n    fromEvent(document, 'mousemove')\n      .pipe(\n        finalize(() => {\n          mouseDown = null;\n          this.resizing = false;\n          this._cdRef.markForCheck();\n          this.updateEditorLayouts();\n        }),\n        takeUntil(\n          fromEvent(this.separator.nativeElement, 'mouseup')\n            .pipe(\n              take(1),\n              takeUntil(this._destroy$),\n            ),\n        ),\n        takeUntil(this._destroy$),\n      )\n      .subscribe((e: any) => {\n        const delta = { x: e.clientX - mouseDown.clientX,\n          y: e.clientY - mouseDown.clientY };\n\n        delta.x = Math.min(Math.max(delta.x, -mouseDown.firstWidth),\n          mouseDown.secondWidth);\n\n        this.separator.nativeElement.style.left = `${mouseDown.offsetLeft + delta.x}px`;\n        this.contentContainer.nativeElement.style.width = `${mouseDown.firstWidth + delta.x}px`;\n        this.styleContainer.nativeElement.style.width = `${mouseDown.secondWidth - delta.x}px`;\n      });\n  }\n}\n","<form fsForm [submit]=\"save\">\n  <fs-dialog>\n    <h1 mat-dialog-title>\n      <div class=\"title-container\">\n        <div class=\"title\">\n          {{title}}\n          <div class=\"small\">{{contentPage.name}}</div>   \n        </div>\n        <a\n            (click)=\"openSettings()\"\n            mat-icon-button>\n          <mat-icon>settings</mat-icon>\n        </a>   \n      </div>\n    </h1>\n    <div mat-dialog-content>\n      <div class=\"container\">\n        <div class=\"editors\" [ngClass]=\"{ resizing: resizing, 'separator-enabled': editors.styles && editors.content }\">\n          <div #contentContainer class=\"editor editor-content\" [ngClass]=\"{ 'content-enabled': editors.content }\">\n            <fs-label>HTML</fs-label>\n            <div class=\"editor-container\">\n              <fs-text-editor \n                #contentEditor\n                [(ngModel)]=\"contentPage.content\" \n                (blur)=\"contentChanged()\"\n                name=\"content\"\n                [config]=\"contentConfig\">\n              </fs-text-editor>              \n            </div>\n          </div>\n          <div  \n            #separator\n            class=\"separator\">\n            <mat-icon>drag_indicator</mat-icon>\n          </div>\n          <div \n              #styleContainer \n              class=\"editor editor-styles\" \n              [ngClass]=\"{ 'styles-enabled': editors.styles }\"\n              [style.width]=\"'600px'\">\n            <fs-label>SCSS</fs-label>\n            <div class=\"editor-container\">\n              <fs-text-editor \n                #styleEditor\n                [(ngModel)]=\"contentPage.styles\" \n                (blur)=\"stylesChanged()\"\n                name=\"styles\"\n                [config]=\"stylesConfig\">\n              </fs-text-editor>    \n            </div>\n          </div>    \n        </div>\n      </div>\n    </div>\n\n    <div mat-dialog-actions>\n      <fs-form-dialog-actions\n        [save]=\"false\"\n        [done]=\"true\">\n      </fs-form-dialog-actions>\n      <div class=\"toggles\">\n        <mat-button-toggle-group multiple>\n          <mat-button-toggle value=\"content\" [checked]=\"editors.content\" (change)=\"editorToggleChange($event)\">Content</mat-button-toggle>\n          <mat-button-toggle value=\"styles\" [checked]=\"editors.styles\" (change)=\"editorToggleChange($event)\">Styles</mat-button-toggle>\n        </mat-button-toggle-group>      \n      </div>\n    </div>\n  </fs-dialog>\n</form>\n\n"]}
123
+ }] }, { type: i1.MatDialogRef }, { type: i2.FsMessage }, { type: i0.ChangeDetectorRef }]; } });
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.component.js","sourceRoot":"","sources":["../../../../../../../src/app/modules/editor/components/editor/editor.component.ts","../../../../../../../src/app/modules/editor/components/editor/editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Inject,\n  OnDestroy,\n  OnInit,\n} from '@angular/core';\n\nimport { MatButtonToggleChange } from '@angular/material/button-toggle';\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\n\nimport { FsMessage } from '@firestitch/message';\nimport { FsTextEditorConfig } from '@firestitch/text-editor';\n\n\nimport { Observable, Subject } from 'rxjs';\nimport { takeUntil, tap } from 'rxjs/operators';\n\nimport { FsContentConfig } from '../../../../interfaces';\n\n\n@Component({\n  templateUrl: './editor.component.html',\n  styleUrls: ['./editor.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class EditorComponent implements OnInit, OnDestroy {\n\n  public contentPage: {\n    id?: number;\n    styles?: string;\n    content?: string;\n    name?: string;\n    js?: string;\n  };\n\n  public contentStyle: {\n    scss?: string;\n  };\n\n  public resizing = false;\n  public title;\n  public editors = {\n    html: true,\n    scss: true,\n    js: false,\n    globalScss: false,\n  };\n\n  public scssConfig: FsTextEditorConfig;\n  public globalScssConfig: FsTextEditorConfig;\n  public htmlConfig: FsTextEditorConfig;\n  public jsConfig: FsTextEditorConfig;\n\n  private _config: FsContentConfig;\n  private _destroy$ = new Subject<void>();\n  private _save: (data) => Observable<any>;\n\n  constructor(\n    @Inject(MAT_DIALOG_DATA) private _data: {\n      contentPage: any;\n      title: string;\n      save: (data) => Observable<any>;\n      openSettings: (data) => Observable<any>;\n      contentConfig: FsContentConfig;\n    },\n    private _dialogRef: MatDialogRef<EditorComponent>,\n    private _message: FsMessage,\n    private _cdRef: ChangeDetectorRef,\n  ) {}\n\n  public ngOnInit(): void {\n    this._dialogRef.addPanelClass('fs-content-editor-overlay-pane');\n    this.title = this._data.title;\n    this.contentPage = this._data.contentPage;\n    this._config = this._data.contentConfig;\n    this._save = this._data.save;\n    this.initTextEditors();\n    this.initGlobalContentStyle();\n  }\n\n  public editorToggleChange(event: MatButtonToggleChange): void {\n    this.editors[event.value] = !this.editors[event.value];\n  }\n\n  public ngOnDestroy(): void {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  public globalScssChange() {\n    this._config.saveContentStyle(this.contentStyle)\n      .subscribe((contentStyle) => {\n        this.contentStyle = contentStyle;\n        this._message.success('Saved Changes');\n        this._cdRef.markForCheck();\n      });\n  }\n\n  public initTextEditors() {\n    this.scssConfig = {\n      tabSize: 2,\n      language: 'scss',\n      height: '100%',\n    };\n    this.jsConfig = {\n      tabSize: 2,\n      language: 'js',\n      height: '100%',\n    };\n    this.htmlConfig = {\n      tabSize: 2,\n      language: 'html',\n      height: '100%',\n    };\n    this.globalScssConfig = {\n      tabSize: 2,\n      language: 'scss',\n      height: '100%',\n    };\n  }\n\n  public initGlobalContentStyle() {\n    this._config.loadContentStyle()\n      .subscribe((contentStyle) => {\n        this.contentStyle = contentStyle;\n        this._cdRef.markForCheck();\n      });\n  }\n\n  public saveContentPage() {\n    this._save({\n      id: this.contentPage.id,\n      styles: this.contentPage.styles,\n      content: this.contentPage.content,\n      js: this.contentPage.js,\n    })\n      .pipe(\n        tap((contentPage) => {\n          this.contentPage = {\n            ...this.contentPage,\n            ...contentPage,\n          };\n          this._cdRef.markForCheck();\n          this._message.success('Saved Changes');\n        }),\n      )\n      .subscribe();\n  }\n\n  public openSettings(): void {\n    this._data.openSettings(this.contentPage)\n      .pipe(\n        takeUntil(this._destroy$),\n      )\n      .subscribe((contentPage) => {\n        this.contentPage = {\n          ...this.contentPage,\n          ...contentPage,\n        };\n        this._cdRef.markForCheck();\n      });\n  }\n\n}\n","<fs-dialog>\n  <h1 mat-dialog-title>\n    <div class=\"title-container\">\n      <div class=\"title\">\n        {{title}}\n        <div class=\"small\">{{contentPage.name}}</div>   \n      </div>\n      <a\n          (click)=\"openSettings()\"\n          mat-icon-button>\n        <mat-icon>settings</mat-icon>\n      </a>   \n    </div>\n  </h1>\n  <div mat-dialog-content>\n    <div class=\"container\">\n      <as-split [unit]=\"'percent'\" [gutterSize]=\"25\"> \n        <as-split-area [size]=\"70\" [visible]=\"editors.html\" [order]=\"1\">\n          <div class=\"editor-container\">\n            <fs-label>HTML</fs-label>\n            <fs-text-editor \n              [(ngModel)]=\"contentPage.content\" \n              name=\"html\"\n              [fsModelChangeOptions]=\"{ debounce: 300 }\"\n              (fsModelChange)=\"saveContentPage()\"\n              [config]=\"htmlConfig\">\n            </fs-text-editor>              \n          </div>\n        </as-split-area>\n        <as-split-area [size]=\"30\" [visible]=\"editors.scss\" [order]=\"2\">\n          <div class=\"editor-container\">\n            <fs-label>SCSS</fs-label>\n            <fs-text-editor \n              [(ngModel)]=\"contentPage.styles\" \n              name=\"scss\"\n              [fsModelChangeOptions]=\"{ debounce: 300 }\"\n              (fsModelChange)=\"saveContentPage()\"\n              [config]=\"scssConfig\">\n            </fs-text-editor>    \n          </div>\n        </as-split-area>\n        <as-split-area [size]=\"30\"  [visible]=\"editors.js\" [order]=\"3\">\n          <div class=\"editor-container\">\n            <fs-label>JS</fs-label>\n            <fs-text-editor \n              [(ngModel)]=\"contentPage.js\" \n              name=\"js\"\n              [fsModelChangeOptions]=\"{ debounce: 300 }\"\n              (fsModelChange)=\"saveContentPage()\"\n              [config]=\"jsConfig\">\n            </fs-text-editor>    \n          </div>\n        </as-split-area>\n        <as-split-area [size]=\"30\" [visible]=\"editors.globalScss\" [order]=\"4\">\n          <div class=\"editor-container\">\n            <fs-label>Global SCSS</fs-label>\n            <ng-container *fsSkeleton=\"contentStyle\">\n              <fs-text-editor \n                [(ngModel)]=\"contentStyle.scss\" \n                name=\"globalScss\"\n                [fsModelChangeOptions]=\"{ debounce: 300 }\"\n                (fsModelChange)=\"globalScssChange()\"\n                [config]=\"globalScssConfig\">\n              </fs-text-editor> \n            </ng-container>   \n          </div>\n        </as-split-area>\n      </as-split>\n    </div>\n  </div>\n\n  <div mat-dialog-actions>\n    <fs-form-dialog-actions\n      [save]=\"false\"\n      [done]=\"true\">\n    </fs-form-dialog-actions>\n    <div class=\"toggles\">\n      <mat-button-toggle-group multiple>\n        <mat-button-toggle value=\"html\" [checked]=\"editors.html\" (change)=\"editorToggleChange($event)\">HTML</mat-button-toggle>\n        <mat-button-toggle value=\"scss\" [checked]=\"editors.scss\" (change)=\"editorToggleChange($event)\">SCSS</mat-button-toggle>\n        <mat-button-toggle value=\"js\" [checked]=\"editors.js\" (change)=\"editorToggleChange($event)\">JS</mat-button-toggle>\n        <mat-button-toggle value=\"globalScss\" [checked]=\"editors.globalScss\" (change)=\"editorToggleChange($event)\">Global SCSS</mat-button-toggle>\n      </mat-button-toggle-group>      \n    </div>\n  </div>\n</fs-dialog>\n\n"]}
@@ -1,17 +1,20 @@
1
- import { NgModule } from '@angular/core';
2
1
  import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { FormsModule } from '@angular/forms';
3
4
  import { MatButtonModule } from '@angular/material/button';
4
- import { MatTabsModule } from '@angular/material/tabs';
5
5
  import { MatButtonToggleModule } from '@angular/material/button-toggle';
6
6
  import { MatDialogModule } from '@angular/material/dialog';
7
7
  import { MatIconModule } from '@angular/material/icon';
8
- import { FormsModule } from '@angular/forms';
9
- import { FsListModule } from '@firestitch/list';
10
- import { FsLabelModule } from '@firestitch/label';
8
+ import { MatTabsModule } from '@angular/material/tabs';
9
+ import { FsCommonModule } from '@firestitch/common';
11
10
  import { FsDialogModule } from '@firestitch/dialog';
12
11
  import { FsFormModule } from '@firestitch/form';
13
12
  import { FsHtmlEditorModule } from '@firestitch/html-editor';
13
+ import { FsLabelModule } from '@firestitch/label';
14
+ import { FsListModule } from '@firestitch/list';
15
+ import { FsSkeletonModule } from '@firestitch/skeleton';
14
16
  import { FsTextEditorModule } from '@firestitch/text-editor';
17
+ import { AngularSplitModule } from 'angular-split';
15
18
  import { EditorComponent } from './components/editor';
16
19
  import * as i0 from "@angular/core";
17
20
  export class FsContentEditorModule {
@@ -26,10 +29,13 @@ FsContentEditorModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", v
26
29
  MatButtonToggleModule,
27
30
  FsListModule,
28
31
  FsFormModule,
32
+ FsSkeletonModule,
29
33
  FsLabelModule,
30
34
  FsHtmlEditorModule,
35
+ FsCommonModule,
31
36
  FsDialogModule,
32
- FsTextEditorModule], exports: [EditorComponent] });
37
+ FsTextEditorModule,
38
+ AngularSplitModule], exports: [EditorComponent] });
33
39
  FsContentEditorModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsContentEditorModule, imports: [[
34
40
  CommonModule,
35
41
  FormsModule,
@@ -40,10 +46,13 @@ FsContentEditorModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", v
40
46
  MatButtonToggleModule,
41
47
  FsListModule,
42
48
  FsFormModule,
49
+ FsSkeletonModule,
43
50
  FsLabelModule,
44
51
  FsHtmlEditorModule,
52
+ FsCommonModule,
45
53
  FsDialogModule,
46
54
  FsTextEditorModule,
55
+ AngularSplitModule,
47
56
  ]] });
48
57
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsContentEditorModule, decorators: [{
49
58
  type: NgModule,
@@ -58,10 +67,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
58
67
  MatButtonToggleModule,
59
68
  FsListModule,
60
69
  FsFormModule,
70
+ FsSkeletonModule,
61
71
  FsLabelModule,
62
72
  FsHtmlEditorModule,
73
+ FsCommonModule,
63
74
  FsDialogModule,
64
75
  FsTextEditorModule,
76
+ AngularSplitModule,
65
77
  ],
66
78
  exports: [
67
79
  EditorComponent,
@@ -71,4 +83,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
71
83
  ],
72
84
  }]
73
85
  }] });
74
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnMtY29udGVudC1lZGl0b3IubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2FwcC9tb2R1bGVzL2VkaXRvci9mcy1jb250ZW50LWVkaXRvci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFL0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUN4RSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUU3QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDaEQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ2xELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUNwRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDaEQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDN0QsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFFN0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDOztBQTRCdEQsTUFBTSxPQUFPLHFCQUFxQjs7bUhBQXJCLHFCQUFxQjtvSEFBckIscUJBQXFCLGlCQUg5QixlQUFlLGFBcEJmLFlBQVk7UUFDWixXQUFXO1FBRVgsZUFBZTtRQUNmLGVBQWU7UUFDZixhQUFhO1FBQ2IsYUFBYTtRQUNiLHFCQUFxQjtRQUVyQixZQUFZO1FBQ1osWUFBWTtRQUNaLGFBQWE7UUFDYixrQkFBa0I7UUFDbEIsY0FBYztRQUNkLGtCQUFrQixhQUdsQixlQUFlO29IQU1OLHFCQUFxQixZQXhCdkI7WUFDUCxZQUFZO1lBQ1osV0FBVztZQUVYLGVBQWU7WUFDZixlQUFlO1lBQ2YsYUFBYTtZQUNiLGFBQWE7WUFDYixxQkFBcUI7WUFFckIsWUFBWTtZQUNaLFlBQVk7WUFDWixhQUFhO1lBQ2Isa0JBQWtCO1lBQ2xCLGNBQWM7WUFDZCxrQkFBa0I7U0FDbkI7NEZBUVUscUJBQXFCO2tCQXpCakMsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixXQUFXO3dCQUVYLGVBQWU7d0JBQ2YsZUFBZTt3QkFDZixhQUFhO3dCQUNiLGFBQWE7d0JBQ2IscUJBQXFCO3dCQUVyQixZQUFZO3dCQUNaLFlBQVk7d0JBQ1osYUFBYTt3QkFDYixrQkFBa0I7d0JBQ2xCLGNBQWM7d0JBQ2Qsa0JBQWtCO3FCQUNuQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsZUFBZTtxQkFDaEI7b0JBQ0QsWUFBWSxFQUFFO3dCQUNaLGVBQWU7cUJBQ2hCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQgeyBNYXRUYWJzTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdGFicyc7XG5pbXBvcnQgeyBNYXRCdXR0b25Ub2dnbGVNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24tdG9nZ2xlJztcbmltcG9ydCB7IE1hdERpYWxvZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuaW1wb3J0IHsgRnNMaXN0TW9kdWxlIH0gZnJvbSAnQGZpcmVzdGl0Y2gvbGlzdCc7XG5pbXBvcnQgeyBGc0xhYmVsTW9kdWxlIH0gZnJvbSAnQGZpcmVzdGl0Y2gvbGFiZWwnO1xuaW1wb3J0IHsgRnNEaWFsb2dNb2R1bGUgfSBmcm9tICdAZmlyZXN0aXRjaC9kaWFsb2cnO1xuaW1wb3J0IHsgRnNGb3JtTW9kdWxlIH0gZnJvbSAnQGZpcmVzdGl0Y2gvZm9ybSc7XG5pbXBvcnQgeyBGc0h0bWxFZGl0b3JNb2R1bGUgfSBmcm9tICdAZmlyZXN0aXRjaC9odG1sLWVkaXRvcic7XG5pbXBvcnQgeyBGc1RleHRFZGl0b3JNb2R1bGUgfSBmcm9tICdAZmlyZXN0aXRjaC90ZXh0LWVkaXRvcic7XG5cbmltcG9ydCB7IEVkaXRvckNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9lZGl0b3InO1xuXG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgRm9ybXNNb2R1bGUsXG5cbiAgICBNYXREaWFsb2dNb2R1bGUsXG4gICAgTWF0QnV0dG9uTW9kdWxlLFxuICAgIE1hdFRhYnNNb2R1bGUsXG4gICAgTWF0SWNvbk1vZHVsZSxcbiAgICBNYXRCdXR0b25Ub2dnbGVNb2R1bGUsXG5cbiAgICBGc0xpc3RNb2R1bGUsXG4gICAgRnNGb3JtTW9kdWxlLFxuICAgIEZzTGFiZWxNb2R1bGUsXG4gICAgRnNIdG1sRWRpdG9yTW9kdWxlLFxuICAgIEZzRGlhbG9nTW9kdWxlLFxuICAgIEZzVGV4dEVkaXRvck1vZHVsZSxcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIEVkaXRvckNvbXBvbmVudCxcbiAgXSxcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgRWRpdG9yQ29tcG9uZW50LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBGc0NvbnRlbnRFZGl0b3JNb2R1bGUge1xuIH1cbiJdfQ==
86
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnMtY29udGVudC1lZGl0b3IubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2FwcC9tb2R1bGVzL2VkaXRvci9mcy1jb250ZW50LWVkaXRvci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRTdDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUN4RSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUV2RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDcEQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNoRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDbEQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2hELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBRTdELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVuRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7O0FBZ0N0RCxNQUFNLE9BQU8scUJBQXFCOzttSEFBckIscUJBQXFCO29IQUFyQixxQkFBcUIsaUJBSDlCLGVBQWUsYUF4QmYsWUFBWTtRQUNaLFdBQVc7UUFFWCxlQUFlO1FBQ2YsZUFBZTtRQUNmLGFBQWE7UUFDYixhQUFhO1FBQ2IscUJBQXFCO1FBRXJCLFlBQVk7UUFDWixZQUFZO1FBQ1osZ0JBQWdCO1FBQ2hCLGFBQWE7UUFDYixrQkFBa0I7UUFDbEIsY0FBYztRQUNkLGNBQWM7UUFDZCxrQkFBa0I7UUFFbEIsa0JBQWtCLGFBR2xCLGVBQWU7b0hBTU4scUJBQXFCLFlBNUJ2QjtZQUNQLFlBQVk7WUFDWixXQUFXO1lBRVgsZUFBZTtZQUNmLGVBQWU7WUFDZixhQUFhO1lBQ2IsYUFBYTtZQUNiLHFCQUFxQjtZQUVyQixZQUFZO1lBQ1osWUFBWTtZQUNaLGdCQUFnQjtZQUNoQixhQUFhO1lBQ2Isa0JBQWtCO1lBQ2xCLGNBQWM7WUFDZCxjQUFjO1lBQ2Qsa0JBQWtCO1lBRWxCLGtCQUFrQjtTQUNuQjs0RkFRVSxxQkFBcUI7a0JBN0JqQyxRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLFdBQVc7d0JBRVgsZUFBZTt3QkFDZixlQUFlO3dCQUNmLGFBQWE7d0JBQ2IsYUFBYTt3QkFDYixxQkFBcUI7d0JBRXJCLFlBQVk7d0JBQ1osWUFBWTt3QkFDWixnQkFBZ0I7d0JBQ2hCLGFBQWE7d0JBQ2Isa0JBQWtCO3dCQUNsQixjQUFjO3dCQUNkLGNBQWM7d0JBQ2Qsa0JBQWtCO3dCQUVsQixrQkFBa0I7cUJBQ25CO29CQUNELE9BQU8sRUFBRTt3QkFDUCxlQUFlO3FCQUNoQjtvQkFDRCxZQUFZLEVBQUU7d0JBQ1osZUFBZTtxQkFDaEI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTWF0QnV0dG9uVG9nZ2xlTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uLXRvZ2dsZSc7XG5pbXBvcnQgeyBNYXREaWFsb2dNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHsgTWF0VGFic01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3RhYnMnO1xuXG5pbXBvcnQgeyBGc0NvbW1vbk1vZHVsZSB9IGZyb20gJ0BmaXJlc3RpdGNoL2NvbW1vbic7XG5pbXBvcnQgeyBGc0RpYWxvZ01vZHVsZSB9IGZyb20gJ0BmaXJlc3RpdGNoL2RpYWxvZyc7XG5pbXBvcnQgeyBGc0Zvcm1Nb2R1bGUgfSBmcm9tICdAZmlyZXN0aXRjaC9mb3JtJztcbmltcG9ydCB7IEZzSHRtbEVkaXRvck1vZHVsZSB9IGZyb20gJ0BmaXJlc3RpdGNoL2h0bWwtZWRpdG9yJztcbmltcG9ydCB7IEZzTGFiZWxNb2R1bGUgfSBmcm9tICdAZmlyZXN0aXRjaC9sYWJlbCc7XG5pbXBvcnQgeyBGc0xpc3RNb2R1bGUgfSBmcm9tICdAZmlyZXN0aXRjaC9saXN0JztcbmltcG9ydCB7IEZzU2tlbGV0b25Nb2R1bGUgfSBmcm9tICdAZmlyZXN0aXRjaC9za2VsZXRvbic7XG5pbXBvcnQgeyBGc1RleHRFZGl0b3JNb2R1bGUgfSBmcm9tICdAZmlyZXN0aXRjaC90ZXh0LWVkaXRvcic7XG5cbmltcG9ydCB7IEFuZ3VsYXJTcGxpdE1vZHVsZSB9IGZyb20gJ2FuZ3VsYXItc3BsaXQnO1xuXG5pbXBvcnQgeyBFZGl0b3JDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvZWRpdG9yJztcblxuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEZvcm1zTW9kdWxlLFxuXG4gICAgTWF0RGlhbG9nTW9kdWxlLFxuICAgIE1hdEJ1dHRvbk1vZHVsZSxcbiAgICBNYXRUYWJzTW9kdWxlLFxuICAgIE1hdEljb25Nb2R1bGUsXG4gICAgTWF0QnV0dG9uVG9nZ2xlTW9kdWxlLFxuXG4gICAgRnNMaXN0TW9kdWxlLFxuICAgIEZzRm9ybU1vZHVsZSxcbiAgICBGc1NrZWxldG9uTW9kdWxlLFxuICAgIEZzTGFiZWxNb2R1bGUsXG4gICAgRnNIdG1sRWRpdG9yTW9kdWxlLFxuICAgIEZzQ29tbW9uTW9kdWxlLFxuICAgIEZzRGlhbG9nTW9kdWxlLFxuICAgIEZzVGV4dEVkaXRvck1vZHVsZSxcblxuICAgIEFuZ3VsYXJTcGxpdE1vZHVsZSxcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIEVkaXRvckNvbXBvbmVudCxcbiAgXSxcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgRWRpdG9yQ29tcG9uZW50LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBGc0NvbnRlbnRFZGl0b3JNb2R1bGUge1xufVxuIl19
@@ -1,8 +1,10 @@
1
- export { FsContentPagesModule } from './app/modules/content-pages/fs-content-pages.module';
2
1
  export { FsContentLayoutsModule } from './app/modules/content-layouts/fs-content-layouts.module';
2
+ export { FsContentPagesModule } from './app/modules/content-pages/fs-content-pages.module';
3
+ export { FsContentStyleModule } from './app/modules/content-style/fs-content-style.module';
3
4
  export { FsContentModule } from './app/modules/content/fs-content.module';
4
- export { FsContentPagesComponent } from './app/modules/content-pages/components/content-pages/content-pages.component';
5
5
  export { FsContentLayoutsComponent } from './app/modules/content-layouts/components/content-layouts/content-layouts.component';
6
+ export { FsContentPagesComponent } from './app/modules/content-pages/components/content-pages/content-pages.component';
7
+ export { ContentStyleComponent } from './app/modules/content-style/components/content-style';
6
8
  export { FsContentComponent } from './app/modules/content/components/content/content.component';
7
9
  export { FS_CONTENT_CONFIG } from './app/injectors/content-config.injector';
8
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHFEQUFxRCxDQUFDO0FBQzNGLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHlEQUF5RCxDQUFDO0FBQ2pHLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUUxRSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw4RUFBOEUsQ0FBQztBQUN2SCxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxvRkFBb0YsQ0FBQztBQUMvSCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw0REFBNEQsQ0FBQztBQUVoRyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IEZzQ29udGVudFBhZ2VzTW9kdWxlIH0gZnJvbSAnLi9hcHAvbW9kdWxlcy9jb250ZW50LXBhZ2VzL2ZzLWNvbnRlbnQtcGFnZXMubW9kdWxlJztcbmV4cG9ydCB7IEZzQ29udGVudExheW91dHNNb2R1bGUgfSBmcm9tICcuL2FwcC9tb2R1bGVzL2NvbnRlbnQtbGF5b3V0cy9mcy1jb250ZW50LWxheW91dHMubW9kdWxlJztcbmV4cG9ydCB7IEZzQ29udGVudE1vZHVsZSB9IGZyb20gJy4vYXBwL21vZHVsZXMvY29udGVudC9mcy1jb250ZW50Lm1vZHVsZSc7XG5cbmV4cG9ydCB7IEZzQ29udGVudFBhZ2VzQ29tcG9uZW50IH0gZnJvbSAnLi9hcHAvbW9kdWxlcy9jb250ZW50LXBhZ2VzL2NvbXBvbmVudHMvY29udGVudC1wYWdlcy9jb250ZW50LXBhZ2VzLmNvbXBvbmVudCc7XG5leHBvcnQgeyBGc0NvbnRlbnRMYXlvdXRzQ29tcG9uZW50IH0gZnJvbSAnLi9hcHAvbW9kdWxlcy9jb250ZW50LWxheW91dHMvY29tcG9uZW50cy9jb250ZW50LWxheW91dHMvY29udGVudC1sYXlvdXRzLmNvbXBvbmVudCc7XG5leHBvcnQgeyBGc0NvbnRlbnRDb21wb25lbnQgfSBmcm9tICcuL2FwcC9tb2R1bGVzL2NvbnRlbnQvY29tcG9uZW50cy9jb250ZW50L2NvbnRlbnQuY29tcG9uZW50JztcblxuZXhwb3J0IHsgRlNfQ09OVEVOVF9DT05GSUcgfSBmcm9tICcuL2FwcC9pbmplY3RvcnMvY29udGVudC1jb25maWcuaW5qZWN0b3InO1xuXG5leHBvcnQgeyBGc0NvbnRlbnRDb25maWcgfSBmcm9tICcuL2FwcC9pbnRlcmZhY2VzL2NvbnRlbnQtY29uZmlnJztcbmV4cG9ydCB7IEZzQ29udGVudFBhZ2UgfSBmcm9tICcuL2FwcC9pbnRlcmZhY2VzL2NvbnRlbnQtcGFnZSc7XG5leHBvcnQgeyBGc0NvbnRlbnRMYXlvdXQgfSBmcm9tICcuL2FwcC9pbnRlcmZhY2VzL2NvbnRlbnQtbGF5b3V0JzsiXX0=
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHlEQUF5RCxDQUFDO0FBQ2pHLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHFEQUFxRCxDQUFDO0FBQzNGLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHFEQUFxRCxDQUFDO0FBQzNGLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUUxRSxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxvRkFBb0YsQ0FBQztBQUMvSCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw4RUFBOEUsQ0FBQztBQUN2SCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxzREFBc0QsQ0FBQztBQUM3RixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw0REFBNEQsQ0FBQztBQUVoRyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IEZzQ29udGVudExheW91dHNNb2R1bGUgfSBmcm9tICcuL2FwcC9tb2R1bGVzL2NvbnRlbnQtbGF5b3V0cy9mcy1jb250ZW50LWxheW91dHMubW9kdWxlJztcbmV4cG9ydCB7IEZzQ29udGVudFBhZ2VzTW9kdWxlIH0gZnJvbSAnLi9hcHAvbW9kdWxlcy9jb250ZW50LXBhZ2VzL2ZzLWNvbnRlbnQtcGFnZXMubW9kdWxlJztcbmV4cG9ydCB7IEZzQ29udGVudFN0eWxlTW9kdWxlIH0gZnJvbSAnLi9hcHAvbW9kdWxlcy9jb250ZW50LXN0eWxlL2ZzLWNvbnRlbnQtc3R5bGUubW9kdWxlJztcbmV4cG9ydCB7IEZzQ29udGVudE1vZHVsZSB9IGZyb20gJy4vYXBwL21vZHVsZXMvY29udGVudC9mcy1jb250ZW50Lm1vZHVsZSc7XG5cbmV4cG9ydCB7IEZzQ29udGVudExheW91dHNDb21wb25lbnQgfSBmcm9tICcuL2FwcC9tb2R1bGVzL2NvbnRlbnQtbGF5b3V0cy9jb21wb25lbnRzL2NvbnRlbnQtbGF5b3V0cy9jb250ZW50LWxheW91dHMuY29tcG9uZW50JztcbmV4cG9ydCB7IEZzQ29udGVudFBhZ2VzQ29tcG9uZW50IH0gZnJvbSAnLi9hcHAvbW9kdWxlcy9jb250ZW50LXBhZ2VzL2NvbXBvbmVudHMvY29udGVudC1wYWdlcy9jb250ZW50LXBhZ2VzLmNvbXBvbmVudCc7XG5leHBvcnQgeyBDb250ZW50U3R5bGVDb21wb25lbnQgfSBmcm9tICcuL2FwcC9tb2R1bGVzL2NvbnRlbnQtc3R5bGUvY29tcG9uZW50cy9jb250ZW50LXN0eWxlJztcbmV4cG9ydCB7IEZzQ29udGVudENvbXBvbmVudCB9IGZyb20gJy4vYXBwL21vZHVsZXMvY29udGVudC9jb21wb25lbnRzL2NvbnRlbnQvY29udGVudC5jb21wb25lbnQnO1xuXG5leHBvcnQgeyBGU19DT05URU5UX0NPTkZJRyB9IGZyb20gJy4vYXBwL2luamVjdG9ycy9jb250ZW50LWNvbmZpZy5pbmplY3Rvcic7XG5cbmV4cG9ydCB7IEZzQ29udGVudENvbmZpZyB9IGZyb20gJy4vYXBwL2ludGVyZmFjZXMvY29udGVudC1jb25maWcnO1xuZXhwb3J0IHsgRnNDb250ZW50TGF5b3V0IH0gZnJvbSAnLi9hcHAvaW50ZXJmYWNlcy9jb250ZW50LWxheW91dCc7XG5leHBvcnQgeyBGc0NvbnRlbnRQYWdlIH0gZnJvbSAnLi9hcHAvaW50ZXJmYWNlcy9jb250ZW50LXBhZ2UnO1xuXG4iXX0=