@firestitch/text-editor 12.3.1 → 12.4.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/app/components/text-editor/text-editor.component.d.ts +2 -2
- package/app/fs-text-editor.module.d.ts +2 -2
- package/app/modules/ngx-monaco-editor/base-editor.d.ts +18 -0
- package/app/modules/ngx-monaco-editor/config.d.ts +9 -0
- package/app/modules/ngx-monaco-editor/diff-editor.component.d.ts +17 -0
- package/app/modules/ngx-monaco-editor/editor.component.d.ts +23 -0
- package/app/modules/ngx-monaco-editor/editor.module.d.ts +12 -0
- package/app/modules/ngx-monaco-editor/types.d.ts +9 -0
- package/bundles/firestitch-text-editor.umd.js +1020 -225
- package/bundles/firestitch-text-editor.umd.js.map +1 -1
- package/esm2015/app/components/text-editor/text-editor.component.js +8 -8
- package/esm2015/app/fs-text-editor.module.js +6 -6
- package/esm2015/app/modules/ngx-monaco-editor/base-editor.js +77 -0
- package/esm2015/app/modules/ngx-monaco-editor/config.js +3 -0
- package/esm2015/app/modules/ngx-monaco-editor/diff-editor.component.js +91 -0
- package/esm2015/app/modules/ngx-monaco-editor/editor.component.js +121 -0
- package/esm2015/app/modules/ngx-monaco-editor/editor.module.js +40 -0
- package/esm2015/app/modules/ngx-monaco-editor/types.js +2 -0
- package/fesm2015/firestitch-text-editor.js +321 -11
- package/fesm2015/firestitch-text-editor.js.map +1 -1
- package/package.json +2 -8
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import { Component, forwardRef, Inject, Input, NgZone } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { fromEvent } from 'rxjs';
|
|
4
|
+
import { BaseEditor } from './base-editor';
|
|
5
|
+
import { NGX_MONACO_EDITOR_CONFIG } from './config';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class EditorComponent extends BaseEditor {
|
|
8
|
+
constructor(zone, editorConfig) {
|
|
9
|
+
super(editorConfig);
|
|
10
|
+
this.zone = zone;
|
|
11
|
+
this.editorConfig = editorConfig;
|
|
12
|
+
this._value = '';
|
|
13
|
+
this.propagateChange = (_) => { };
|
|
14
|
+
this.onTouched = () => { };
|
|
15
|
+
}
|
|
16
|
+
set options(options) {
|
|
17
|
+
this._options = Object.assign({}, this.config.defaultOptions, options);
|
|
18
|
+
if (this._editor) {
|
|
19
|
+
this._editor.dispose();
|
|
20
|
+
this.initMonaco(options);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
get options() {
|
|
24
|
+
return this._options;
|
|
25
|
+
}
|
|
26
|
+
set model(model) {
|
|
27
|
+
this.options.model = model;
|
|
28
|
+
if (this._editor) {
|
|
29
|
+
this._editor.dispose();
|
|
30
|
+
this.initMonaco(this.options);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
writeValue(value) {
|
|
34
|
+
this._value = value || '';
|
|
35
|
+
// Fix for value change while dispose in process.
|
|
36
|
+
setTimeout(() => {
|
|
37
|
+
if (this._editor && !this.options.model) {
|
|
38
|
+
this._editor.setValue(this._value);
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
registerOnChange(fn) {
|
|
43
|
+
this.propagateChange = fn;
|
|
44
|
+
}
|
|
45
|
+
registerOnTouched(fn) {
|
|
46
|
+
this.onTouched = fn;
|
|
47
|
+
}
|
|
48
|
+
initMonaco(options) {
|
|
49
|
+
const hasModel = !!options.model;
|
|
50
|
+
if (hasModel) {
|
|
51
|
+
const model = monaco.editor.getModel(options.model.uri || '');
|
|
52
|
+
if (model) {
|
|
53
|
+
options.model = model;
|
|
54
|
+
options.model.setValue(this._value);
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
options.model = monaco.editor.createModel(options.model.value, options.model.language, options.model.uri);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
this._editor = monaco.editor.create(this._editorContainer.nativeElement, options);
|
|
61
|
+
if (!hasModel) {
|
|
62
|
+
this._editor.setValue(this._value);
|
|
63
|
+
}
|
|
64
|
+
this._editor.onDidChangeModelContent((e) => {
|
|
65
|
+
const value = this._editor.getValue();
|
|
66
|
+
// value is not propagated to parent when executing outside zone.
|
|
67
|
+
this.zone.run(() => {
|
|
68
|
+
this.propagateChange(value);
|
|
69
|
+
this._value = value;
|
|
70
|
+
});
|
|
71
|
+
});
|
|
72
|
+
this._editor.onDidBlurEditorWidget(() => {
|
|
73
|
+
this.onTouched();
|
|
74
|
+
});
|
|
75
|
+
// refresh layout on resize event.
|
|
76
|
+
if (this._windowResizeSubscription) {
|
|
77
|
+
this._windowResizeSubscription.unsubscribe();
|
|
78
|
+
}
|
|
79
|
+
this._windowResizeSubscription = fromEvent(window, 'resize').subscribe(() => this._editor.layout());
|
|
80
|
+
this.onInit.emit(this._editor);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
EditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: EditorComponent, deps: [{ token: i0.NgZone }, { token: NGX_MONACO_EDITOR_CONFIG }], target: i0.ɵɵFactoryTarget.Component });
|
|
84
|
+
EditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: EditorComponent, selector: "ngx-monaco-editor", inputs: { options: "options", model: "model" }, providers: [{
|
|
85
|
+
provide: NG_VALUE_ACCESSOR,
|
|
86
|
+
useExisting: forwardRef(() => EditorComponent),
|
|
87
|
+
multi: true
|
|
88
|
+
}], usesInheritance: true, ngImport: i0, template: '<div class="editor-container" #editorContainer></div>', isInline: true, styles: ["\n :host {\n display: block;\n height: 200px;\n }\n\n .editor-container {\n width: 100%;\n height: 98%;\n }\n "] });
|
|
89
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: EditorComponent, decorators: [{
|
|
90
|
+
type: Component,
|
|
91
|
+
args: [{
|
|
92
|
+
selector: 'ngx-monaco-editor',
|
|
93
|
+
template: '<div class="editor-container" #editorContainer></div>',
|
|
94
|
+
styles: [`
|
|
95
|
+
:host {
|
|
96
|
+
display: block;
|
|
97
|
+
height: 200px;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
.editor-container {
|
|
101
|
+
width: 100%;
|
|
102
|
+
height: 98%;
|
|
103
|
+
}
|
|
104
|
+
`],
|
|
105
|
+
providers: [{
|
|
106
|
+
provide: NG_VALUE_ACCESSOR,
|
|
107
|
+
useExisting: forwardRef(() => EditorComponent),
|
|
108
|
+
multi: true
|
|
109
|
+
}]
|
|
110
|
+
}]
|
|
111
|
+
}], ctorParameters: function () { return [{ type: i0.NgZone }, { type: undefined, decorators: [{
|
|
112
|
+
type: Inject,
|
|
113
|
+
args: [NGX_MONACO_EDITOR_CONFIG]
|
|
114
|
+
}] }]; }, propDecorators: { options: [{
|
|
115
|
+
type: Input,
|
|
116
|
+
args: ['options']
|
|
117
|
+
}], model: [{
|
|
118
|
+
type: Input,
|
|
119
|
+
args: ['model']
|
|
120
|
+
}] } });
|
|
121
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.component.js","sourceRoot":"","sources":["../../../../../src/app/modules/ngx-monaco-editor/editor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Inject, Input, NgZone } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { fromEvent } from 'rxjs';\n\nimport { BaseEditor } from './base-editor';\nimport { NGX_MONACO_EDITOR_CONFIG, NgxMonacoEditorConfig } from './config';\nimport { NgxEditorModel } from './types';\n\ndeclare var monaco: any;\n\n@Component({\n  selector: 'ngx-monaco-editor',\n  template: '<div class=\"editor-container\" #editorContainer></div>',\n  styles: [`\n      :host {\n          display: block;\n          height: 200px;\n      }\n\n      .editor-container {\n          width: 100%;\n          height: 98%;\n      }\n  `],\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => EditorComponent),\n    multi: true\n  }]\n})\nexport class EditorComponent extends BaseEditor implements ControlValueAccessor {\n  private _value: string = '';\n\n  propagateChange = (_: any) => {};\n  onTouched = () => {};\n\n  @Input('options')\n  set options(options: any) {\n    this._options = Object.assign({}, this.config.defaultOptions, options);\n    if (this._editor) {\n      this._editor.dispose();\n      this.initMonaco(options);\n    }\n  }\n\n  get options(): any {\n    return this._options;\n  }\n\n  @Input('model')\n  set model(model: NgxEditorModel) {\n    this.options.model = model;\n    if (this._editor) {\n      this._editor.dispose();\n      this.initMonaco(this.options);\n    }\n  }\n\n  constructor(private zone: NgZone, @Inject(NGX_MONACO_EDITOR_CONFIG) private editorConfig: NgxMonacoEditorConfig) {\n    super(editorConfig);\n  }\n\n  writeValue(value: any): void {\n    this._value = value || '';\n    // Fix for value change while dispose in process.\n    setTimeout(() => {\n      if (this._editor && !this.options.model) {\n        this._editor.setValue(this._value);\n      }\n    });\n  }\n\n  registerOnChange(fn: any): void {\n    this.propagateChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  protected initMonaco(options: any): void {\n\n    const hasModel = !!options.model;\n\n    if (hasModel) {\n      const model = monaco.editor.getModel(options.model.uri || '');\n      if (model) {\n        options.model = model;\n        options.model.setValue(this._value);\n      } else {\n        options.model = monaco.editor.createModel(options.model.value, options.model.language, options.model.uri);\n      }\n    }\n\n    this._editor = monaco.editor.create(this._editorContainer.nativeElement, options);\n\n    if (!hasModel) {\n      this._editor.setValue(this._value);\n    }\n\n    this._editor.onDidChangeModelContent((e: any) => {\n      const value = this._editor.getValue();\n\n      // value is not propagated to parent when executing outside zone.\n      this.zone.run(() => {\n        this.propagateChange(value);\n        this._value = value;\n      });\n    });\n\n    this._editor.onDidBlurEditorWidget(() => {\n      this.onTouched();\n    });\n\n    // refresh layout on resize event.\n    if (this._windowResizeSubscription) {\n      this._windowResizeSubscription.unsubscribe();\n    }\n    this._windowResizeSubscription = fromEvent(window, 'resize').subscribe(() => this._editor.layout());\n    this.onInit.emit(this._editor);\n  }\n\n}\n"]}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { NGX_MONACO_EDITOR_CONFIG } from './config';
|
|
4
|
+
import { DiffEditorComponent } from './diff-editor.component';
|
|
5
|
+
import { EditorComponent } from './editor.component';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class MonacoEditorModule {
|
|
8
|
+
static forRoot(config = {}) {
|
|
9
|
+
return {
|
|
10
|
+
ngModule: MonacoEditorModule,
|
|
11
|
+
providers: [
|
|
12
|
+
{ provide: NGX_MONACO_EDITOR_CONFIG, useValue: config }
|
|
13
|
+
]
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
MonacoEditorModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MonacoEditorModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
18
|
+
MonacoEditorModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MonacoEditorModule, declarations: [EditorComponent,
|
|
19
|
+
DiffEditorComponent], imports: [CommonModule], exports: [EditorComponent,
|
|
20
|
+
DiffEditorComponent] });
|
|
21
|
+
MonacoEditorModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MonacoEditorModule, imports: [[
|
|
22
|
+
CommonModule
|
|
23
|
+
]] });
|
|
24
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MonacoEditorModule, decorators: [{
|
|
25
|
+
type: NgModule,
|
|
26
|
+
args: [{
|
|
27
|
+
imports: [
|
|
28
|
+
CommonModule
|
|
29
|
+
],
|
|
30
|
+
declarations: [
|
|
31
|
+
EditorComponent,
|
|
32
|
+
DiffEditorComponent
|
|
33
|
+
],
|
|
34
|
+
exports: [
|
|
35
|
+
EditorComponent,
|
|
36
|
+
DiffEditorComponent
|
|
37
|
+
]
|
|
38
|
+
}]
|
|
39
|
+
}] });
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdG9yLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvbW9kdWxlcy9uZ3gtbW9uYWNvLWVkaXRvci9lZGl0b3IubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQXVCLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUU5RCxPQUFPLEVBQUUsd0JBQXdCLEVBQXlCLE1BQU0sVUFBVSxDQUFDO0FBQzNFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzlELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQzs7QUFlckQsTUFBTSxPQUFPLGtCQUFrQjtJQUN0QixNQUFNLENBQUMsT0FBTyxDQUFDLFNBQWdDLEVBQUU7UUFDdEQsT0FBTztZQUNMLFFBQVEsRUFBRSxrQkFBa0I7WUFDNUIsU0FBUyxFQUFFO2dCQUNULEVBQUUsT0FBTyxFQUFFLHdCQUF3QixFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUU7YUFDeEQ7U0FDRixDQUFDO0lBQ0osQ0FBQzs7Z0hBUlUsa0JBQWtCO2lIQUFsQixrQkFBa0IsaUJBUjNCLGVBQWU7UUFDZixtQkFBbUIsYUFKbkIsWUFBWSxhQU9aLGVBQWU7UUFDZixtQkFBbUI7aUhBR1Ysa0JBQWtCLFlBWnBCO1lBQ1AsWUFBWTtTQUNiOzRGQVVVLGtCQUFrQjtrQkFiOUIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTtxQkFDYjtvQkFDRCxZQUFZLEVBQUU7d0JBQ1osZUFBZTt3QkFDZixtQkFBbUI7cUJBQ3BCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxlQUFlO3dCQUNmLG1CQUFtQjtxQkFDcEI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTW9kdWxlV2l0aFByb3ZpZGVycywgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgTkdYX01PTkFDT19FRElUT1JfQ09ORklHLCBOZ3hNb25hY29FZGl0b3JDb25maWcgfSBmcm9tICcuL2NvbmZpZyc7XG5pbXBvcnQgeyBEaWZmRWRpdG9yQ29tcG9uZW50IH0gZnJvbSAnLi9kaWZmLWVkaXRvci5jb21wb25lbnQnO1xuaW1wb3J0IHsgRWRpdG9yQ29tcG9uZW50IH0gZnJvbSAnLi9lZGl0b3IuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZVxuICBdLFxuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBFZGl0b3JDb21wb25lbnQsXG4gICAgRGlmZkVkaXRvckNvbXBvbmVudFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgRWRpdG9yQ29tcG9uZW50LFxuICAgIERpZmZFZGl0b3JDb21wb25lbnRcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBNb25hY29FZGl0b3JNb2R1bGUge1xuICBwdWJsaWMgc3RhdGljIGZvclJvb3QoY29uZmlnOiBOZ3hNb25hY29FZGl0b3JDb25maWcgPSB7fSk6IE1vZHVsZVdpdGhQcm92aWRlcnM8TW9uYWNvRWRpdG9yTW9kdWxlPiB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG5nTW9kdWxlOiBNb25hY29FZGl0b3JNb2R1bGUsXG4gICAgICBwcm92aWRlcnM6IFtcbiAgICAgICAgeyBwcm92aWRlOiBOR1hfTU9OQUNPX0VESVRPUl9DT05GSUcsIHVzZVZhbHVlOiBjb25maWcgfVxuICAgICAgXVxuICAgIH07XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvYXBwL21vZHVsZXMvbmd4LW1vbmFjby1lZGl0b3IvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgRGlmZkVkaXRvck1vZGVsIHtcbiAgICBjb2RlOiBzdHJpbmc7XG4gICAgbGFuZ3VhZ2U6IHN0cmluZztcbn1cbmV4cG9ydCBpbnRlcmZhY2UgTmd4RWRpdG9yTW9kZWwge1xuICAgIHZhbHVlOiBzdHJpbmc7XG4gICAgbGFuZ3VhZ2U/OiBzdHJpbmc7XG4gICAgdXJpPzogYW55O1xufVxuIl19
|
|
@@ -1,10 +1,200 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { InjectionToken, EventEmitter, Component, Inject, ViewChild, Output, forwardRef, Input, NgModule } from '@angular/core';
|
|
3
3
|
import { DOCUMENT, CommonModule } from '@angular/common';
|
|
4
4
|
import * as i2 from '@angular/forms';
|
|
5
5
|
import { NG_VALUE_ACCESSOR, FormsModule } from '@angular/forms';
|
|
6
|
-
import
|
|
7
|
-
|
|
6
|
+
import { fromEvent } from 'rxjs';
|
|
7
|
+
|
|
8
|
+
const NGX_MONACO_EDITOR_CONFIG = new InjectionToken('NGX_MONACO_EDITOR_CONFIG');
|
|
9
|
+
|
|
10
|
+
let loadedMonaco = false;
|
|
11
|
+
let loadPromise;
|
|
12
|
+
class BaseEditor {
|
|
13
|
+
constructor(config) {
|
|
14
|
+
this.config = config;
|
|
15
|
+
this.onInit = new EventEmitter();
|
|
16
|
+
}
|
|
17
|
+
ngAfterViewInit() {
|
|
18
|
+
if (loadedMonaco) {
|
|
19
|
+
// Wait until monaco editor is available
|
|
20
|
+
loadPromise.then(() => {
|
|
21
|
+
this.initMonaco(this._options);
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
loadedMonaco = true;
|
|
26
|
+
loadPromise = new Promise((resolve) => {
|
|
27
|
+
const baseUrl = (this.config.baseUrl || './assets') + '/monaco-editor/min/vs';
|
|
28
|
+
if (typeof (window.monaco) === 'object') {
|
|
29
|
+
resolve();
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
const onGotAmdLoader = () => {
|
|
33
|
+
// Load monaco
|
|
34
|
+
window.require.config({ paths: { 'vs': `${baseUrl}` } });
|
|
35
|
+
window.require([`vs/editor/editor.main`], () => {
|
|
36
|
+
if (typeof this.config.onMonacoLoad === 'function') {
|
|
37
|
+
this.config.onMonacoLoad();
|
|
38
|
+
}
|
|
39
|
+
this.initMonaco(this._options);
|
|
40
|
+
resolve();
|
|
41
|
+
});
|
|
42
|
+
};
|
|
43
|
+
// Load AMD loader if necessary
|
|
44
|
+
if (!window.require) {
|
|
45
|
+
const loaderScript = document.createElement('script');
|
|
46
|
+
loaderScript.type = 'text/javascript';
|
|
47
|
+
loaderScript.src = `${baseUrl}/loader.js`;
|
|
48
|
+
loaderScript.addEventListener('load', onGotAmdLoader);
|
|
49
|
+
document.body.appendChild(loaderScript);
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
onGotAmdLoader();
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
ngOnDestroy() {
|
|
58
|
+
if (this._windowResizeSubscription) {
|
|
59
|
+
this._windowResizeSubscription.unsubscribe();
|
|
60
|
+
}
|
|
61
|
+
if (this._editor) {
|
|
62
|
+
this._editor.dispose();
|
|
63
|
+
this._editor = undefined;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
BaseEditor.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: BaseEditor, deps: [{ token: NGX_MONACO_EDITOR_CONFIG }], target: i0.ɵɵFactoryTarget.Component });
|
|
68
|
+
BaseEditor.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: BaseEditor, selector: "ng-component", outputs: { onInit: "onInit" }, viewQueries: [{ propertyName: "_editorContainer", first: true, predicate: ["editorContainer"], descendants: true, static: true }], ngImport: i0, template: '', isInline: true });
|
|
69
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: BaseEditor, decorators: [{
|
|
70
|
+
type: Component,
|
|
71
|
+
args: [{
|
|
72
|
+
template: ''
|
|
73
|
+
}]
|
|
74
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
75
|
+
type: Inject,
|
|
76
|
+
args: [NGX_MONACO_EDITOR_CONFIG]
|
|
77
|
+
}] }]; }, propDecorators: { _editorContainer: [{
|
|
78
|
+
type: ViewChild,
|
|
79
|
+
args: ['editorContainer', { static: true }]
|
|
80
|
+
}], onInit: [{
|
|
81
|
+
type: Output
|
|
82
|
+
}] } });
|
|
83
|
+
|
|
84
|
+
class EditorComponent extends BaseEditor {
|
|
85
|
+
constructor(zone, editorConfig) {
|
|
86
|
+
super(editorConfig);
|
|
87
|
+
this.zone = zone;
|
|
88
|
+
this.editorConfig = editorConfig;
|
|
89
|
+
this._value = '';
|
|
90
|
+
this.propagateChange = (_) => { };
|
|
91
|
+
this.onTouched = () => { };
|
|
92
|
+
}
|
|
93
|
+
set options(options) {
|
|
94
|
+
this._options = Object.assign({}, this.config.defaultOptions, options);
|
|
95
|
+
if (this._editor) {
|
|
96
|
+
this._editor.dispose();
|
|
97
|
+
this.initMonaco(options);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
get options() {
|
|
101
|
+
return this._options;
|
|
102
|
+
}
|
|
103
|
+
set model(model) {
|
|
104
|
+
this.options.model = model;
|
|
105
|
+
if (this._editor) {
|
|
106
|
+
this._editor.dispose();
|
|
107
|
+
this.initMonaco(this.options);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
writeValue(value) {
|
|
111
|
+
this._value = value || '';
|
|
112
|
+
// Fix for value change while dispose in process.
|
|
113
|
+
setTimeout(() => {
|
|
114
|
+
if (this._editor && !this.options.model) {
|
|
115
|
+
this._editor.setValue(this._value);
|
|
116
|
+
}
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
registerOnChange(fn) {
|
|
120
|
+
this.propagateChange = fn;
|
|
121
|
+
}
|
|
122
|
+
registerOnTouched(fn) {
|
|
123
|
+
this.onTouched = fn;
|
|
124
|
+
}
|
|
125
|
+
initMonaco(options) {
|
|
126
|
+
const hasModel = !!options.model;
|
|
127
|
+
if (hasModel) {
|
|
128
|
+
const model = monaco.editor.getModel(options.model.uri || '');
|
|
129
|
+
if (model) {
|
|
130
|
+
options.model = model;
|
|
131
|
+
options.model.setValue(this._value);
|
|
132
|
+
}
|
|
133
|
+
else {
|
|
134
|
+
options.model = monaco.editor.createModel(options.model.value, options.model.language, options.model.uri);
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
this._editor = monaco.editor.create(this._editorContainer.nativeElement, options);
|
|
138
|
+
if (!hasModel) {
|
|
139
|
+
this._editor.setValue(this._value);
|
|
140
|
+
}
|
|
141
|
+
this._editor.onDidChangeModelContent((e) => {
|
|
142
|
+
const value = this._editor.getValue();
|
|
143
|
+
// value is not propagated to parent when executing outside zone.
|
|
144
|
+
this.zone.run(() => {
|
|
145
|
+
this.propagateChange(value);
|
|
146
|
+
this._value = value;
|
|
147
|
+
});
|
|
148
|
+
});
|
|
149
|
+
this._editor.onDidBlurEditorWidget(() => {
|
|
150
|
+
this.onTouched();
|
|
151
|
+
});
|
|
152
|
+
// refresh layout on resize event.
|
|
153
|
+
if (this._windowResizeSubscription) {
|
|
154
|
+
this._windowResizeSubscription.unsubscribe();
|
|
155
|
+
}
|
|
156
|
+
this._windowResizeSubscription = fromEvent(window, 'resize').subscribe(() => this._editor.layout());
|
|
157
|
+
this.onInit.emit(this._editor);
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
EditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: EditorComponent, deps: [{ token: i0.NgZone }, { token: NGX_MONACO_EDITOR_CONFIG }], target: i0.ɵɵFactoryTarget.Component });
|
|
161
|
+
EditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: EditorComponent, selector: "ngx-monaco-editor", inputs: { options: "options", model: "model" }, providers: [{
|
|
162
|
+
provide: NG_VALUE_ACCESSOR,
|
|
163
|
+
useExisting: forwardRef(() => EditorComponent),
|
|
164
|
+
multi: true
|
|
165
|
+
}], usesInheritance: true, ngImport: i0, template: '<div class="editor-container" #editorContainer></div>', isInline: true, styles: ["\n :host {\n display: block;\n height: 200px;\n }\n\n .editor-container {\n width: 100%;\n height: 98%;\n }\n "] });
|
|
166
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: EditorComponent, decorators: [{
|
|
167
|
+
type: Component,
|
|
168
|
+
args: [{
|
|
169
|
+
selector: 'ngx-monaco-editor',
|
|
170
|
+
template: '<div class="editor-container" #editorContainer></div>',
|
|
171
|
+
styles: [`
|
|
172
|
+
:host {
|
|
173
|
+
display: block;
|
|
174
|
+
height: 200px;
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
.editor-container {
|
|
178
|
+
width: 100%;
|
|
179
|
+
height: 98%;
|
|
180
|
+
}
|
|
181
|
+
`],
|
|
182
|
+
providers: [{
|
|
183
|
+
provide: NG_VALUE_ACCESSOR,
|
|
184
|
+
useExisting: forwardRef(() => EditorComponent),
|
|
185
|
+
multi: true
|
|
186
|
+
}]
|
|
187
|
+
}]
|
|
188
|
+
}], ctorParameters: function () { return [{ type: i0.NgZone }, { type: undefined, decorators: [{
|
|
189
|
+
type: Inject,
|
|
190
|
+
args: [NGX_MONACO_EDITOR_CONFIG]
|
|
191
|
+
}] }]; }, propDecorators: { options: [{
|
|
192
|
+
type: Input,
|
|
193
|
+
args: ['options']
|
|
194
|
+
}], model: [{
|
|
195
|
+
type: Input,
|
|
196
|
+
args: ['model']
|
|
197
|
+
}] } });
|
|
8
198
|
|
|
9
199
|
class FsTextEditorComponent {
|
|
10
200
|
constructor(_element, _document) {
|
|
@@ -115,13 +305,13 @@ class FsTextEditorComponent {
|
|
|
115
305
|
}, true);
|
|
116
306
|
}
|
|
117
307
|
}
|
|
118
|
-
FsTextEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.
|
|
119
|
-
FsTextEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.
|
|
308
|
+
FsTextEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FsTextEditorComponent, deps: [{ token: i0.ElementRef }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Component });
|
|
309
|
+
FsTextEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: FsTextEditorComponent, selector: "fs-text-editor", inputs: { config: "config", scrollable: "scrollable" }, outputs: { init: "init", blur: "blur" }, providers: [{
|
|
120
310
|
provide: NG_VALUE_ACCESSOR,
|
|
121
311
|
useExisting: forwardRef(() => FsTextEditorComponent),
|
|
122
312
|
multi: true
|
|
123
|
-
}], viewQueries: [{ propertyName: "_editorContainer", first: true, predicate: EditorComponent, descendants: true, static: true }], ngImport: i0, template: "<ngx-monaco-editor\n [ngModel]=\"value\"\n (ngModelChange)=\"changed($event)\"\n [options]=\"config\"\n (onInit)=\"onEditorInit($event)\">\n</ngx-monaco-editor>\n", styles: [":host ngx-monaco-editor{height:100%!important}:host ::ng-deep .decorationsOverviewRuler{display:none}:host ::ng-deep .margin,:host ::ng-deep .monaco-editor-background{top:0px!important}\n"], components: [{ type:
|
|
124
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.
|
|
313
|
+
}], viewQueries: [{ propertyName: "_editorContainer", first: true, predicate: EditorComponent, descendants: true, static: true }], ngImport: i0, template: "<ngx-monaco-editor\n [ngModel]=\"value\"\n (ngModelChange)=\"changed($event)\"\n [options]=\"config\"\n (onInit)=\"onEditorInit($event)\">\n</ngx-monaco-editor>\n", styles: [":host ngx-monaco-editor{height:100%!important}:host ::ng-deep .decorationsOverviewRuler{display:none}:host ::ng-deep .margin,:host ::ng-deep .monaco-editor-background{top:0px!important}\n"], components: [{ type: EditorComponent, selector: "ngx-monaco-editor", inputs: ["options", "model"] }], directives: [{ type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
|
|
314
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FsTextEditorComponent, decorators: [{
|
|
125
315
|
type: Component,
|
|
126
316
|
args: [{
|
|
127
317
|
selector: 'fs-text-editor',
|
|
@@ -149,6 +339,126 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
149
339
|
args: [EditorComponent, { static: true }]
|
|
150
340
|
}] } });
|
|
151
341
|
|
|
342
|
+
class DiffEditorComponent extends BaseEditor {
|
|
343
|
+
constructor(editorConfig) {
|
|
344
|
+
super(editorConfig);
|
|
345
|
+
this.editorConfig = editorConfig;
|
|
346
|
+
}
|
|
347
|
+
set options(options) {
|
|
348
|
+
this._options = Object.assign({}, this.config.defaultOptions, options);
|
|
349
|
+
if (this._editor) {
|
|
350
|
+
this._editor.dispose();
|
|
351
|
+
this.initMonaco(options);
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
get options() {
|
|
355
|
+
return this._options;
|
|
356
|
+
}
|
|
357
|
+
set originalModel(model) {
|
|
358
|
+
this._originalModel = model;
|
|
359
|
+
if (this._editor) {
|
|
360
|
+
this._editor.dispose();
|
|
361
|
+
this.initMonaco(this.options);
|
|
362
|
+
}
|
|
363
|
+
}
|
|
364
|
+
set modifiedModel(model) {
|
|
365
|
+
this._modifiedModel = model;
|
|
366
|
+
if (this._editor) {
|
|
367
|
+
this._editor.dispose();
|
|
368
|
+
this.initMonaco(this.options);
|
|
369
|
+
}
|
|
370
|
+
}
|
|
371
|
+
initMonaco(options) {
|
|
372
|
+
if (!this._originalModel || !this._modifiedModel) {
|
|
373
|
+
throw new Error('originalModel or modifiedModel not found for ngx-monaco-diff-editor');
|
|
374
|
+
}
|
|
375
|
+
this._originalModel.language = this._originalModel.language || options.language;
|
|
376
|
+
this._modifiedModel.language = this._modifiedModel.language || options.language;
|
|
377
|
+
let originalModel = monaco.editor.createModel(this._originalModel.code, this._originalModel.language);
|
|
378
|
+
let modifiedModel = monaco.editor.createModel(this._modifiedModel.code, this._modifiedModel.language);
|
|
379
|
+
this._editorContainer.nativeElement.innerHTML = '';
|
|
380
|
+
const theme = options.theme;
|
|
381
|
+
this._editor = monaco.editor.createDiffEditor(this._editorContainer.nativeElement, options);
|
|
382
|
+
options.theme = theme;
|
|
383
|
+
this._editor.setModel({
|
|
384
|
+
original: originalModel,
|
|
385
|
+
modified: modifiedModel
|
|
386
|
+
});
|
|
387
|
+
// refresh layout on resize event.
|
|
388
|
+
if (this._windowResizeSubscription) {
|
|
389
|
+
this._windowResizeSubscription.unsubscribe();
|
|
390
|
+
}
|
|
391
|
+
this._windowResizeSubscription = fromEvent(window, 'resize').subscribe(() => this._editor.layout());
|
|
392
|
+
this.onInit.emit(this._editor);
|
|
393
|
+
}
|
|
394
|
+
}
|
|
395
|
+
DiffEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: DiffEditorComponent, deps: [{ token: NGX_MONACO_EDITOR_CONFIG }], target: i0.ɵɵFactoryTarget.Component });
|
|
396
|
+
DiffEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: DiffEditorComponent, selector: "ngx-monaco-diff-editor", inputs: { options: "options", originalModel: "originalModel", modifiedModel: "modifiedModel" }, usesInheritance: true, ngImport: i0, template: '<div class="editor-container" #editorContainer></div>', isInline: true, styles: ["\n :host {\n display: block;\n height: 200px;\n }\n\n .editor-container {\n width: 100%;\n height: 98%;\n }\n "] });
|
|
397
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: DiffEditorComponent, decorators: [{
|
|
398
|
+
type: Component,
|
|
399
|
+
args: [{
|
|
400
|
+
selector: 'ngx-monaco-diff-editor',
|
|
401
|
+
template: '<div class="editor-container" #editorContainer></div>',
|
|
402
|
+
styles: [`
|
|
403
|
+
:host {
|
|
404
|
+
display: block;
|
|
405
|
+
height: 200px;
|
|
406
|
+
}
|
|
407
|
+
|
|
408
|
+
.editor-container {
|
|
409
|
+
width: 100%;
|
|
410
|
+
height: 98%;
|
|
411
|
+
}
|
|
412
|
+
`]
|
|
413
|
+
}]
|
|
414
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
415
|
+
type: Inject,
|
|
416
|
+
args: [NGX_MONACO_EDITOR_CONFIG]
|
|
417
|
+
}] }]; }, propDecorators: { options: [{
|
|
418
|
+
type: Input,
|
|
419
|
+
args: ['options']
|
|
420
|
+
}], originalModel: [{
|
|
421
|
+
type: Input,
|
|
422
|
+
args: ['originalModel']
|
|
423
|
+
}], modifiedModel: [{
|
|
424
|
+
type: Input,
|
|
425
|
+
args: ['modifiedModel']
|
|
426
|
+
}] } });
|
|
427
|
+
|
|
428
|
+
class MonacoEditorModule {
|
|
429
|
+
static forRoot(config = {}) {
|
|
430
|
+
return {
|
|
431
|
+
ngModule: MonacoEditorModule,
|
|
432
|
+
providers: [
|
|
433
|
+
{ provide: NGX_MONACO_EDITOR_CONFIG, useValue: config }
|
|
434
|
+
]
|
|
435
|
+
};
|
|
436
|
+
}
|
|
437
|
+
}
|
|
438
|
+
MonacoEditorModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MonacoEditorModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
439
|
+
MonacoEditorModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MonacoEditorModule, declarations: [EditorComponent,
|
|
440
|
+
DiffEditorComponent], imports: [CommonModule], exports: [EditorComponent,
|
|
441
|
+
DiffEditorComponent] });
|
|
442
|
+
MonacoEditorModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MonacoEditorModule, imports: [[
|
|
443
|
+
CommonModule
|
|
444
|
+
]] });
|
|
445
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MonacoEditorModule, decorators: [{
|
|
446
|
+
type: NgModule,
|
|
447
|
+
args: [{
|
|
448
|
+
imports: [
|
|
449
|
+
CommonModule
|
|
450
|
+
],
|
|
451
|
+
declarations: [
|
|
452
|
+
EditorComponent,
|
|
453
|
+
DiffEditorComponent
|
|
454
|
+
],
|
|
455
|
+
exports: [
|
|
456
|
+
EditorComponent,
|
|
457
|
+
DiffEditorComponent
|
|
458
|
+
]
|
|
459
|
+
}]
|
|
460
|
+
}] });
|
|
461
|
+
|
|
152
462
|
class FsTextEditorModule {
|
|
153
463
|
static forRoot(config) {
|
|
154
464
|
return {
|
|
@@ -159,16 +469,16 @@ class FsTextEditorModule {
|
|
|
159
469
|
};
|
|
160
470
|
}
|
|
161
471
|
}
|
|
162
|
-
FsTextEditorModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.
|
|
163
|
-
FsTextEditorModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.
|
|
472
|
+
FsTextEditorModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FsTextEditorModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
473
|
+
FsTextEditorModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FsTextEditorModule, declarations: [FsTextEditorComponent], imports: [CommonModule,
|
|
164
474
|
MonacoEditorModule,
|
|
165
475
|
FormsModule], exports: [FsTextEditorComponent] });
|
|
166
|
-
FsTextEditorModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.
|
|
476
|
+
FsTextEditorModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FsTextEditorModule, imports: [[
|
|
167
477
|
CommonModule,
|
|
168
478
|
MonacoEditorModule,
|
|
169
479
|
FormsModule,
|
|
170
480
|
]] });
|
|
171
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.
|
|
481
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FsTextEditorModule, decorators: [{
|
|
172
482
|
type: NgModule,
|
|
173
483
|
args: [{
|
|
174
484
|
imports: [
|