@firestitch/content 12.2.5 → 12.2.7
Sign up to get free protection for your applications and to get access to all the features.
- package/app/enums/editor-type.d.ts +6 -0
- package/app/enums/index.d.ts +1 -0
- package/app/modules/content-layouts/components/content-layout-editor/content-layout-editor.component.d.ts +12 -4
- package/app/modules/content-pages/components/content-page-editor/content-page-editor.component.d.ts +10 -3
- package/app/modules/editor/components/editor/editor.component.d.ts +12 -4
- package/bundles/firestitch-content.umd.js +336 -173
- package/bundles/firestitch-content.umd.js.map +1 -1
- package/esm2015/app/enums/editor-type.js +8 -0
- package/esm2015/app/enums/index.js +2 -1
- package/esm2015/app/modules/content-layouts/components/content-layout-editor/content-layout-editor.component.js +87 -34
- package/esm2015/app/modules/content-pages/components/content-page-editor/content-page-editor.component.js +89 -37
- package/esm2015/app/modules/content-pages/components/content-pages/content-pages.component.js +2 -2
- package/esm2015/app/modules/editor/components/editor/editor.component.js +58 -13
- package/fesm2015/firestitch-content.js +238 -91
- package/fesm2015/firestitch-content.js.map +1 -1
- package/package.json +1 -1
@@ -1,6 +1,8 @@
|
|
1
1
|
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, } from '@angular/core';
|
2
2
|
import { FsMessage } from '@firestitch/message';
|
3
3
|
import { Subject } from 'rxjs';
|
4
|
+
import { tap } from 'rxjs/operators';
|
5
|
+
import { EditorType } from '../../../../enums';
|
4
6
|
import * as i0 from "@angular/core";
|
5
7
|
import * as i1 from "@firestitch/message";
|
6
8
|
import * as i2 from "angular-split";
|
@@ -11,14 +13,18 @@ import * as i6 from "@firestitch/form";
|
|
11
13
|
import * as i7 from "@firestitch/common";
|
12
14
|
import * as i8 from "@firestitch/skeleton";
|
13
15
|
export class EditorComponent {
|
14
|
-
constructor(
|
15
|
-
this._message = _message;
|
16
|
+
constructor(_cdRef, _message) {
|
16
17
|
this._cdRef = _cdRef;
|
18
|
+
this._message = _message;
|
17
19
|
this.showHtml = false;
|
18
20
|
this.showScss = false;
|
19
21
|
this.showJs = false;
|
20
22
|
this.showGlobalScss = false;
|
21
23
|
this.changed = new EventEmitter();
|
24
|
+
this.focused = new EventEmitter();
|
25
|
+
this.blured = new EventEmitter();
|
26
|
+
this.changes = {};
|
27
|
+
this.EditorType = EditorType;
|
22
28
|
this.resizing = false;
|
23
29
|
this._destroy$ = new Subject();
|
24
30
|
}
|
@@ -30,34 +36,63 @@ export class EditorComponent {
|
|
30
36
|
this._destroy$.next();
|
31
37
|
this._destroy$.complete();
|
32
38
|
}
|
33
|
-
|
34
|
-
this.
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
39
|
+
change(type, value) {
|
40
|
+
this.changed.emit({ type, value });
|
41
|
+
this.changes[type] = value;
|
42
|
+
}
|
43
|
+
get hasChanges() {
|
44
|
+
return Object.keys(this.changes)
|
45
|
+
.filter((name) => !!this.changes[name])
|
46
|
+
.length !== 0;
|
47
|
+
}
|
48
|
+
clearChange(type) {
|
49
|
+
this.changes[type] = null;
|
50
|
+
this._cdRef.markForCheck();
|
40
51
|
}
|
41
52
|
initTextEditors() {
|
42
53
|
this.scssConfig = {
|
43
54
|
tabSize: 2,
|
44
55
|
language: 'scss',
|
45
56
|
height: '100%',
|
57
|
+
focus: () => {
|
58
|
+
this.focused.emit(EditorType.Scss);
|
59
|
+
},
|
60
|
+
blur: () => {
|
61
|
+
this.blured.emit(EditorType.Scss);
|
62
|
+
},
|
46
63
|
};
|
47
64
|
this.jsConfig = {
|
48
65
|
tabSize: 2,
|
49
66
|
language: 'js',
|
50
67
|
height: '100%',
|
68
|
+
focus: () => {
|
69
|
+
this.focused.emit(EditorType.Js);
|
70
|
+
},
|
71
|
+
blur: () => {
|
72
|
+
this.blured.emit(EditorType.Js);
|
73
|
+
},
|
51
74
|
};
|
52
75
|
this.htmlConfig = {
|
53
76
|
tabSize: 2,
|
54
77
|
language: 'html',
|
55
78
|
height: '100%',
|
79
|
+
focus: () => {
|
80
|
+
this.focused.emit(EditorType.Html);
|
81
|
+
},
|
82
|
+
blur: () => {
|
83
|
+
this.blured.emit(EditorType.Html);
|
84
|
+
},
|
56
85
|
};
|
57
86
|
this.globalScssConfig = {
|
58
87
|
tabSize: 2,
|
59
88
|
language: 'scss',
|
60
89
|
height: '100%',
|
90
|
+
focus: () => {
|
91
|
+
this.focused.emit(EditorType.GlobalScss);
|
92
|
+
},
|
93
|
+
blur: () => {
|
94
|
+
this.blured.emit(EditorType.GlobalScss);
|
95
|
+
},
|
61
96
|
};
|
62
97
|
}
|
63
98
|
initGlobalContentStyle() {
|
@@ -67,9 +102,15 @@ export class EditorComponent {
|
|
67
102
|
this._cdRef.markForCheck();
|
68
103
|
});
|
69
104
|
}
|
105
|
+
saveGlobalScss() {
|
106
|
+
return this.contentConfig.saveContentStyle(this.contentStyle)
|
107
|
+
.pipe(tap(() => {
|
108
|
+
this._message.success('Saved Changes');
|
109
|
+
}));
|
110
|
+
}
|
70
111
|
}
|
71
|
-
EditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: EditorComponent, deps: [{ token:
|
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:
|
112
|
+
EditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: EditorComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.FsMessage }], target: i0.ɵɵFactoryTarget.Component });
|
113
|
+
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", focused: "focused", blured: "blured" }, 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 {{changes.html ? '*' : ''}}</fs-label>\n <fs-text-editor \n [(ngModel)]=\"html\" \n name=\"html\"\n [fsModelChangeOptions]=\"{ debounce: 0 }\"\n (fsModelChange)=\"change(EditorType.Html, $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 {{changes.scss ? '*' : ''}}</fs-label>\n <fs-text-editor \n [(ngModel)]=\"scss\" \n name=\"scss\"\n [fsModelChangeOptions]=\"{ debounce: 0 }\"\n (fsModelChange)=\"change(EditorType.Scss, $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 {{changes.js ? '*' : ''}}</fs-label>\n <fs-text-editor \n [(ngModel)]=\"js\" \n name=\"js\"\n [fsModelChangeOptions]=\"{ debounce: 0 }\"\n (fsModelChange)=\"change(EditorType.Js, $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 {{changes.globalScss ? '*' : ''}}</fs-label>\n <ng-container *fsSkeleton=\"contentStyle\">\n <fs-text-editor \n [(ngModel)]=\"contentStyle.scss\" \n name=\"globalScss\"\n [fsModelChangeOptions]=\"{ debounce: 300 }\"\n (fsModelChange)=\"change(EditorType.GlobalScss, $event)\"\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 });
|
73
114
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: EditorComponent, decorators: [{
|
74
115
|
type: Component,
|
75
116
|
args: [{
|
@@ -78,7 +119,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
78
119
|
styleUrls: ['./editor.component.scss'],
|
79
120
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
80
121
|
}]
|
81
|
-
}], ctorParameters: function () { return [{ type:
|
122
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.FsMessage }]; }, propDecorators: { showHtml: [{
|
82
123
|
type: Input
|
83
124
|
}], showScss: [{
|
84
125
|
type: Input
|
@@ -96,5 +137,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
96
137
|
type: Input
|
97
138
|
}], changed: [{
|
98
139
|
type: Output
|
140
|
+
}], focused: [{
|
141
|
+
type: Output
|
142
|
+
}], blured: [{
|
143
|
+
type: Output
|
99
144
|
}] } });
|
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"]}
|
145
|
+
//# 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  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\nimport { Subject } from 'rxjs';\nimport { tap } from 'rxjs/operators';\n\nimport { EditorType } from '../../../../enums';\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  @Output() public focused = new EventEmitter<string>();\n  @Output() public blured = new EventEmitter<string>();\n\n  public changes: any = {};\n  public EditorType = EditorType;\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 _cdRef: ChangeDetectorRef,\n    private _message: FsMessage,\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 change(type, value) {\n    this.changed.emit({ type, value });\n    this.changes[type] = value;\n  }\n\n  public get hasChanges() {\n    return Object.keys(this.changes)\n      .filter((name) => !!this.changes[name])\n      .length !== 0;\n  }\n\n  public clearChange(type) {\n    this.changes[type] = null;\n    this._cdRef.markForCheck();\n  }\n\n  public initTextEditors() {\n    this.scssConfig = {\n      tabSize: 2,\n      language: 'scss',\n      height: '100%',\n      focus: () => {\n        this.focused.emit(EditorType.Scss);\n      },\n      blur: () => {\n        this.blured.emit(EditorType.Scss);\n      },\n    };\n    this.jsConfig = {\n      tabSize: 2,\n      language: 'js',\n      height: '100%',\n      focus: () => {\n        this.focused.emit(EditorType.Js);\n      },\n      blur: () => {\n        this.blured.emit(EditorType.Js);\n      },\n    };\n    this.htmlConfig = {\n      tabSize: 2,\n      language: 'html',\n      height: '100%',\n      focus: () => {\n        this.focused.emit(EditorType.Html);\n      },\n      blur: () => {\n        this.blured.emit(EditorType.Html);\n      },\n    };\n    this.globalScssConfig = {\n      tabSize: 2,\n      language: 'scss',\n      height: '100%',\n      focus: () => {\n        this.focused.emit(EditorType.GlobalScss);\n      },\n      blur: () => {\n        this.blured.emit(EditorType.GlobalScss);\n      },\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  public saveGlobalScss() {\n    return this.contentConfig.saveContentStyle(this.contentStyle)\n      .pipe(\n        tap(() => {\n          this._message.success('Saved Changes');\n        }),\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 {{changes.html ? '*' : ''}}</fs-label>\n      <fs-text-editor \n        [(ngModel)]=\"html\" \n        name=\"html\"\n        [fsModelChangeOptions]=\"{ debounce: 0 }\"\n        (fsModelChange)=\"change(EditorType.Html, $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 {{changes.scss ? '*' : ''}}</fs-label>\n      <fs-text-editor \n        [(ngModel)]=\"scss\" \n        name=\"scss\"\n        [fsModelChangeOptions]=\"{ debounce: 0 }\"\n        (fsModelChange)=\"change(EditorType.Scss, $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 {{changes.js ? '*' : ''}}</fs-label>\n      <fs-text-editor \n        [(ngModel)]=\"js\" \n        name=\"js\"\n        [fsModelChangeOptions]=\"{ debounce: 0 }\"\n        (fsModelChange)=\"change(EditorType.Js, $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 {{changes.globalScss ? '*' : ''}}</fs-label>\n      <ng-container *fsSkeleton=\"contentStyle\">\n        <fs-text-editor \n          [(ngModel)]=\"contentStyle.scss\" \n          name=\"globalScss\"\n          [fsModelChangeOptions]=\"{ debounce: 300 }\"\n          (fsModelChange)=\"change(EditorType.GlobalScss, $event)\"\n          [config]=\"globalScssConfig\">\n        </fs-text-editor> \n      </ng-container>   \n    </div>\n  </as-split-area>\n</as-split>\n"]}
|