@firestitch/content 12.2.4 → 12.2.6

Sign up to get free protection for your applications and to get access to all the features.
Files changed (27) hide show
  1. package/app/interfaces/content-config.d.ts +2 -0
  2. package/app/modules/content-layouts/components/content-layout-editor/content-layout-editor.component.d.ts +41 -0
  3. package/app/modules/content-layouts/components/content-layout-editor/index.d.ts +1 -0
  4. package/app/modules/content-layouts/components/index.d.ts +3 -0
  5. package/app/modules/content-layouts/fs-content-layouts.module.d.ts +21 -20
  6. package/app/modules/content-pages/components/content-page-editor/content-page-editor.component.d.ts +43 -0
  7. package/app/modules/content-pages/components/content-page-editor/index.d.ts +1 -0
  8. package/app/modules/content-pages/components/index.d.ts +3 -0
  9. package/app/modules/content-pages/fs-content-pages.module.d.ts +22 -20
  10. package/app/modules/editor/components/editor/editor.component.d.ts +15 -32
  11. package/bundles/firestitch-content.umd.js +397 -251
  12. package/bundles/firestitch-content.umd.js.map +1 -1
  13. package/esm2015/app/interfaces/content-config.js +1 -1
  14. package/esm2015/app/modules/content-layouts/components/content-layout-editor/content-layout-editor.component.js +95 -0
  15. package/esm2015/app/modules/content-layouts/components/content-layout-editor/index.js +2 -0
  16. package/esm2015/app/modules/content-layouts/components/content-layouts/content-layouts.component.js +4 -11
  17. package/esm2015/app/modules/content-layouts/components/index.js +4 -0
  18. package/esm2015/app/modules/content-layouts/fs-content-layouts.module.js +10 -7
  19. package/esm2015/app/modules/content-pages/components/content-page-editor/content-page-editor.component.js +99 -0
  20. package/esm2015/app/modules/content-pages/components/content-page-editor/index.js +2 -0
  21. package/esm2015/app/modules/content-pages/components/content-pages/content-pages.component.js +4 -11
  22. package/esm2015/app/modules/content-pages/components/index.js +4 -0
  23. package/esm2015/app/modules/content-pages/fs-content-pages.module.js +9 -2
  24. package/esm2015/app/modules/editor/components/editor/editor.component.js +41 -65
  25. package/fesm2015/firestitch-content.js +243 -105
  26. package/fesm2015/firestitch-content.js.map +1 -1
  27. package/package.json +1 -1
@@ -1,55 +1,37 @@
1
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, } from '@angular/core';
2
- import { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, } from '@angular/core';
3
2
  import { FsMessage } from '@firestitch/message';
4
3
  import { Subject } from 'rxjs';
5
- import { takeUntil, tap } from 'rxjs/operators';
6
4
  import * as i0 from "@angular/core";
7
- import * as i1 from "@angular/material/dialog";
8
- import * as i2 from "@firestitch/message";
9
- import * as i3 from "@firestitch/dialog";
10
- import * as i4 from "@angular/material/button";
11
- import * as i5 from "@angular/material/icon";
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";
5
+ import * as i1 from "@firestitch/message";
6
+ import * as i2 from "angular-split";
7
+ import * as i3 from "@firestitch/label";
8
+ import * as i4 from "@firestitch/text-editor";
9
+ import * as i5 from "@angular/forms";
10
+ import * as i6 from "@firestitch/form";
11
+ import * as i7 from "@firestitch/common";
12
+ import * as i8 from "@firestitch/skeleton";
20
13
  export class EditorComponent {
21
- constructor(_data, _dialogRef, _message, _cdRef) {
22
- this._data = _data;
23
- this._dialogRef = _dialogRef;
14
+ constructor(_message, _cdRef) {
24
15
  this._message = _message;
25
16
  this._cdRef = _cdRef;
17
+ this.showHtml = false;
18
+ this.showScss = false;
19
+ this.showJs = false;
20
+ this.showGlobalScss = false;
21
+ this.changed = new EventEmitter();
26
22
  this.resizing = false;
27
- this.editors = {
28
- html: true,
29
- scss: true,
30
- js: false,
31
- globalScss: false,
32
- };
33
23
  this._destroy$ = new Subject();
34
24
  }
35
25
  ngOnInit() {
36
- this._dialogRef.addPanelClass('fs-content-editor-overlay-pane');
37
- this.title = this._data.title;
38
- this.contentPage = this._data.contentPage;
39
- this._config = this._data.contentConfig;
40
- this._save = this._data.save;
41
26
  this.initTextEditors();
42
27
  this.initGlobalContentStyle();
43
28
  }
44
- editorToggleChange(event) {
45
- this.editors[event.value] = !this.editors[event.value];
46
- }
47
29
  ngOnDestroy() {
48
30
  this._destroy$.next();
49
31
  this._destroy$.complete();
50
32
  }
51
33
  globalScssChange() {
52
- this._config.saveContentStyle(this.contentStyle)
34
+ this.contentConfig.saveContentStyle(this.contentStyle)
53
35
  .subscribe((contentStyle) => {
54
36
  this.contentStyle = contentStyle;
55
37
  this._message.success('Saved Changes');
@@ -79,46 +61,40 @@ export class EditorComponent {
79
61
  };
80
62
  }
81
63
  initGlobalContentStyle() {
82
- this._config.loadContentStyle()
64
+ this.contentConfig.loadContentStyle()
83
65
  .subscribe((contentStyle) => {
84
- this.contentStyle = contentStyle;
85
- this._cdRef.markForCheck();
86
- });
87
- }
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,
94
- })
95
- .pipe(tap((contentPage) => {
96
- this.contentPage = Object.assign(Object.assign({}, this.contentPage), contentPage);
97
- this._cdRef.markForCheck();
98
- this._message.success('Saved Changes');
99
- }))
100
- .subscribe();
101
- }
102
- openSettings() {
103
- this._data.openSettings(this.contentPage)
104
- .pipe(takeUntil(this._destroy$))
105
- .subscribe((contentPage) => {
106
- this.contentPage = Object.assign(Object.assign({}, this.contentPage), contentPage);
66
+ this.contentStyle = contentStyle || {};
107
67
  this._cdRef.markForCheck();
108
68
  });
109
69
  }
110
70
  }
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 });
71
+ EditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: EditorComponent, deps: [{ token: i1.FsMessage }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
72
+ EditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: EditorComponent, selector: "app-editor", inputs: { showHtml: "showHtml", showScss: "showScss", showJs: "showJs", showGlobalScss: "showGlobalScss", html: "html", scss: "scss", js: "js", contentConfig: "contentConfig" }, outputs: { changed: "changed" }, ngImport: i0, template: "<as-split [unit]=\"'percent'\" [gutterSize]=\"25\"> \n <as-split-area [size]=\"70\" [visible]=\"showHtml\" [order]=\"1\">\n <div class=\"editor-container\">\n <fs-label>HTML</fs-label>\n <fs-text-editor \n [(ngModel)]=\"html\" \n name=\"html\"\n [fsModelChangeOptions]=\"{ debounce: 300 }\"\n (fsModelChange)=\"changed.emit({ type: 'html', value: $event })\"\n [config]=\"htmlConfig\">\n </fs-text-editor> \n </div>\n </as-split-area>\n <as-split-area [size]=\"30\" [visible]=\"showScss\" [order]=\"2\">\n <div class=\"editor-container\">\n <fs-label>SCSS</fs-label>\n <fs-text-editor \n [(ngModel)]=\"scss\" \n name=\"scss\"\n [fsModelChangeOptions]=\"{ debounce: 300 }\"\n (fsModelChange)=\"changed.emit({ type: 'scss', value: $event })\"\n [config]=\"scssConfig\">\n </fs-text-editor> \n </div>\n </as-split-area>\n <as-split-area [size]=\"30\" [visible]=\"showJs\" [order]=\"3\">\n <div class=\"editor-container\">\n <fs-label>JS</fs-label>\n <fs-text-editor \n [(ngModel)]=\"js\" \n name=\"js\"\n [fsModelChangeOptions]=\"{ debounce: 300 }\"\n (fsModelChange)=\"changed.emit({ type: 'js', value: $event })\"\n [config]=\"jsConfig\">\n </fs-text-editor> \n </div>\n </as-split-area>\n <as-split-area [size]=\"30\" [visible]=\"showGlobalScss\" [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", styles: [":host ::ng-deep .as-split-gutter{background-color:unset!important}.editor-container{height:100%;border-radius:5px;display:flex;flex-direction:column}.editor-container fs-text-editor{flex:1}\n"], components: [{ type: i2.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: i3.FsLabelComponent, selector: "fs-label" }, { type: i4.FsTextEditorComponent, selector: "fs-text-editor", inputs: ["config", "scrollable"], outputs: ["ready", "blur"] }], directives: [{ type: i2.SplitAreaDirective, selector: "as-split-area, [as-split-area]", inputs: ["order", "size", "minSize", "maxSize", "lockSize", "visible"], exportAs: ["asSplitArea"] }, { type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i6.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: i7.FsModelChangeDirective, selector: "[fsModelChange]", inputs: ["fsModelChangeOptions"], outputs: ["fsModelChange"] }, { type: i8.FsSkeletonContentDirective, selector: "[fsSkeleton]", inputs: ["fsSkeleton", "fsSkeletonPattern"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
113
73
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: EditorComponent, decorators: [{
114
74
  type: Component,
115
75
  args: [{
76
+ selector: 'app-editor',
116
77
  templateUrl: './editor.component.html',
117
78
  styleUrls: ['./editor.component.scss'],
118
79
  changeDetection: ChangeDetectionStrategy.OnPush,
119
80
  }]
120
- }], ctorParameters: function () { return [{ type: undefined, decorators: [{
121
- type: Inject,
122
- args: [MAT_DIALOG_DATA]
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"]}
81
+ }], ctorParameters: function () { return [{ type: i1.FsMessage }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { showHtml: [{
82
+ type: Input
83
+ }], showScss: [{
84
+ type: Input
85
+ }], showJs: [{
86
+ type: Input
87
+ }], showGlobalScss: [{
88
+ type: Input
89
+ }], html: [{
90
+ type: Input
91
+ }], scss: [{
92
+ type: Input
93
+ }], js: [{
94
+ type: Input
95
+ }], contentConfig: [{
96
+ type: Input
97
+ }], changed: [{
98
+ type: Output
99
+ }] } });
100
+ //# 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":"AAAA,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,KAAK,EAGL,MAAM,GACP,MAAM,eAAe,CAAC;AAGvB,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAIhD,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;;;;;;;;;;AAW/B,MAAM,OAAO,eAAe;IA4B1B,YACU,QAAmB,EACnB,MAAyB;QADzB,aAAQ,GAAR,QAAQ,CAAW;QACnB,WAAM,GAAN,MAAM,CAAmB;QA5BnB,aAAQ,GAAG,KAAK,CAAC;QACjB,aAAQ,GAAG,KAAK,CAAC;QACjB,WAAM,GAAG,KAAK,CAAC;QACf,mBAAc,GAAG,KAAK,CAAC;QAOtB,YAAO,GAAG,IAAI,YAAY,EAAmC,CAAC;QAMxE,aAAQ,GAAG,KAAK,CAAC;QAQhB,cAAS,GAAG,IAAI,OAAO,EAAQ,CAAC;IAKrC,CAAC;IAEG,QAAQ;QACb,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAChC,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;IAEM,gBAAgB;QACrB,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,IAAI,CAAC,YAAY,CAAC;aACnD,SAAS,CAAC,CAAC,YAAY,EAAE,EAAE;YAC1B,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;YACjC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;YACvC,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAC;IACP,CAAC;IAEM,eAAe;QACpB,IAAI,CAAC,UAAU,GAAG;YAChB,OAAO,EAAE,CAAC;YACV,QAAQ,EAAE,MAAM;YAChB,MAAM,EAAE,MAAM;SACf,CAAC;QACF,IAAI,CAAC,QAAQ,GAAG;YACd,OAAO,EAAE,CAAC;YACV,QAAQ,EAAE,IAAI;YACd,MAAM,EAAE,MAAM;SACf,CAAC;QACF,IAAI,CAAC,UAAU,GAAG;YAChB,OAAO,EAAE,CAAC;YACV,QAAQ,EAAE,MAAM;YAChB,MAAM,EAAE,MAAM;SACf,CAAC;QACF,IAAI,CAAC,gBAAgB,GAAG;YACtB,OAAO,EAAE,CAAC;YACV,QAAQ,EAAE,MAAM;YAChB,MAAM,EAAE,MAAM;SACf,CAAC;IACJ,CAAC;IAEM,sBAAsB;QAC3B,IAAI,CAAC,aAAa,CAAC,gBAAgB,EAAE;aAClC,SAAS,CAAC,CAAC,YAAY,EAAE,EAAE;YAC1B,IAAI,CAAC,YAAY,GAAG,YAAY,IAAI,EAAE,CAAC;YACvC,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAC;IACP,CAAC;;6GAjFU,eAAe;iGAAf,eAAe,qQC3B5B,m5DAoDA;4FDzBa,eAAe;kBAN3B,SAAS;mBAAC;oBACT,QAAQ,EAAE,YAAY;oBACtB,WAAW,EAAE,yBAAyB;oBACtC,SAAS,EAAE,CAAC,yBAAyB,CAAC;oBACtC,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD;gIAGiB,QAAQ;sBAAvB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,MAAM;sBAArB,KAAK;gBACU,cAAc;sBAA7B,KAAK;gBAEU,IAAI;sBAAnB,KAAK;gBACU,IAAI;sBAAnB,KAAK;gBACU,EAAE;sBAAjB,KAAK;gBACU,aAAa;sBAA5B,KAAK;gBAEW,OAAO;sBAAvB,MAAM","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n} from '@angular/core';\n\n\nimport { FsMessage } from '@firestitch/message';\nimport { FsTextEditorConfig } from '@firestitch/text-editor';\n\n\nimport { Subject } from 'rxjs';\n\nimport { FsContentConfig } from '../../../../interfaces';\n\n\n@Component({\n  selector: 'app-editor',\n  templateUrl: './editor.component.html',\n  styleUrls: ['./editor.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class EditorComponent implements OnInit, OnDestroy {\n\n  @Input() public showHtml = false;\n  @Input() public showScss = false;\n  @Input() public showJs = false;\n  @Input() public showGlobalScss = false;\n\n  @Input() public html;\n  @Input() public scss;\n  @Input() public js ;\n  @Input() public contentConfig: FsContentConfig;\n\n  @Output() public changed = new EventEmitter<{ type: string; value: string }>();\n\n  public contentStyle: {\n    scss?: string;\n  };\n\n  public resizing = false;\n  public title;\n\n  public scssConfig: FsTextEditorConfig;\n  public globalScssConfig: FsTextEditorConfig;\n  public htmlConfig: FsTextEditorConfig;\n  public jsConfig: FsTextEditorConfig;\n\n  private _destroy$ = new Subject<void>();\n\n  constructor(\n    private _message: FsMessage,\n    private _cdRef: ChangeDetectorRef,\n  ) {}\n\n  public ngOnInit(): void {\n    this.initTextEditors();\n    this.initGlobalContentStyle();\n  }\n\n  public ngOnDestroy(): void {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  public globalScssChange() {\n    this.contentConfig.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.contentConfig.loadContentStyle()\n      .subscribe((contentStyle) => {\n        this.contentStyle = contentStyle || {};\n        this._cdRef.markForCheck();\n      });\n  }\n\n}\n","<as-split [unit]=\"'percent'\" [gutterSize]=\"25\"> \n  <as-split-area [size]=\"70\" [visible]=\"showHtml\" [order]=\"1\">\n    <div class=\"editor-container\">\n      <fs-label>HTML</fs-label>\n      <fs-text-editor \n        [(ngModel)]=\"html\" \n        name=\"html\"\n        [fsModelChangeOptions]=\"{ debounce: 300 }\"\n        (fsModelChange)=\"changed.emit({ type: 'html', value: $event })\"\n        [config]=\"htmlConfig\">\n      </fs-text-editor>              \n    </div>\n  </as-split-area>\n  <as-split-area [size]=\"30\" [visible]=\"showScss\" [order]=\"2\">\n    <div class=\"editor-container\">\n      <fs-label>SCSS</fs-label>\n      <fs-text-editor \n        [(ngModel)]=\"scss\" \n        name=\"scss\"\n        [fsModelChangeOptions]=\"{ debounce: 300 }\"\n        (fsModelChange)=\"changed.emit({ type: 'scss', value: $event })\"\n        [config]=\"scssConfig\">\n      </fs-text-editor>    \n    </div>\n  </as-split-area>\n  <as-split-area [size]=\"30\"  [visible]=\"showJs\" [order]=\"3\">\n    <div class=\"editor-container\">\n      <fs-label>JS</fs-label>\n      <fs-text-editor \n        [(ngModel)]=\"js\" \n        name=\"js\"\n        [fsModelChangeOptions]=\"{ debounce: 300 }\"\n        (fsModelChange)=\"changed.emit({ type: 'js', value: $event })\"\n        [config]=\"jsConfig\">\n      </fs-text-editor>    \n    </div>\n  </as-split-area>\n  <as-split-area [size]=\"30\" [visible]=\"showGlobalScss\" [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"]}