@gravitee/ui-particles-angular 15.8.0 → 15.8.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/esm2022/lib/gio-monaco-editor/gio-monaco-clipboard-copy.component.mjs +15 -8
- package/esm2022/lib/gio-monaco-editor/gio-monaco-editor.component.mjs +39 -10
- package/fesm2022/gravitee-ui-particles-angular.mjs +50 -15
- package/fesm2022/gravitee-ui-particles-angular.mjs.map +1 -1
- package/lib/gio-monaco-editor/gio-monaco-clipboard-copy.component.d.ts +3 -1
- package/lib/gio-monaco-editor/gio-monaco-editor.component.d.ts +4 -1
- package/package.json +1 -1
|
@@ -13,25 +13,32 @@
|
|
|
13
13
|
* See the License for the specific language governing permissions and
|
|
14
14
|
* limitations under the License.
|
|
15
15
|
*/
|
|
16
|
-
import { Component } from '@angular/core';
|
|
16
|
+
import { Component, ContentChild } from '@angular/core';
|
|
17
|
+
import { GioMonacoEditorComponent } from './gio-monaco-editor.component';
|
|
17
18
|
import * as i0 from "@angular/core";
|
|
18
19
|
import * as i1 from "../gio-clipboard/gio-clipboard-copy-icon.component";
|
|
19
20
|
export class GioMonacoClipboardCopyComponent {
|
|
21
|
+
constructor() {
|
|
22
|
+
this.monacoEditor = null;
|
|
23
|
+
}
|
|
20
24
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.4", ngImport: i0, type: GioMonacoClipboardCopyComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
21
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.4", type: GioMonacoClipboardCopyComponent, isStandalone: false, selector: "[gioMonacoClipboardCopy]", ngImport: i0, template: `
|
|
25
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.4", type: GioMonacoClipboardCopyComponent, isStandalone: false, selector: "[gioMonacoClipboardCopy]", queries: [{ propertyName: "monacoEditor", first: true, predicate: GioMonacoEditorComponent, descendants: true }], ngImport: i0, template: `
|
|
22
26
|
<div class="editor-wrapper">
|
|
23
27
|
<ng-content></ng-content>
|
|
24
|
-
<gio-clipboard-copy-icon class="copy-btn"></gio-clipboard-copy-icon>
|
|
28
|
+
<gio-clipboard-copy-icon class="copy-btn" [contentToCopy]="monacoEditor?.value ?? ''"></gio-clipboard-copy-icon>
|
|
25
29
|
</div>
|
|
26
|
-
`, isInline: true, styles: [".editor-wrapper{position:relative;overflow:auto;
|
|
30
|
+
`, isInline: true, styles: [".editor-wrapper{position:relative;overflow:auto;flex:1 1 50%}.copy-btn{position:absolute;z-index:10;top:8px;right:8px}\n"], dependencies: [{ kind: "component", type: i1.GioClipboardCopyIconComponent, selector: "gio-clipboard-copy-icon" }] }); }
|
|
27
31
|
}
|
|
28
32
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.4", ngImport: i0, type: GioMonacoClipboardCopyComponent, decorators: [{
|
|
29
33
|
type: Component,
|
|
30
34
|
args: [{ selector: '[gioMonacoClipboardCopy]', template: `
|
|
31
35
|
<div class="editor-wrapper">
|
|
32
36
|
<ng-content></ng-content>
|
|
33
|
-
<gio-clipboard-copy-icon class="copy-btn"></gio-clipboard-copy-icon>
|
|
37
|
+
<gio-clipboard-copy-icon class="copy-btn" [contentToCopy]="monacoEditor?.value ?? ''"></gio-clipboard-copy-icon>
|
|
34
38
|
</div>
|
|
35
|
-
`, standalone: false, styles: [".editor-wrapper{position:relative;overflow:auto;
|
|
36
|
-
}]
|
|
37
|
-
|
|
39
|
+
`, standalone: false, styles: [".editor-wrapper{position:relative;overflow:auto;flex:1 1 50%}.copy-btn{position:absolute;z-index:10;top:8px;right:8px}\n"] }]
|
|
40
|
+
}], propDecorators: { monacoEditor: [{
|
|
41
|
+
type: ContentChild,
|
|
42
|
+
args: [GioMonacoEditorComponent, { static: false }]
|
|
43
|
+
}] } });
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2lvLW1vbmFjby1jbGlwYm9hcmQtY29weS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1wYXJ0aWNsZXMtYW5ndWxhci9zcmMvbGliL2dpby1tb25hY28tZWRpdG9yL2dpby1tb25hY28tY2xpcGJvYXJkLWNvcHkuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7OztHQWNHO0FBQ0gsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFeEQsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sK0JBQStCLENBQUM7OztBQWN6RSxNQUFNLE9BQU8sK0JBQStCO0lBWjVDO1FBY1MsaUJBQVksR0FBb0MsSUFBSSxDQUFDO0tBQzdEOzhHQUhZLCtCQUErQjtrR0FBL0IsK0JBQStCLCtIQUM1Qix3QkFBd0IsZ0RBVDVCOzs7OztHQUtUOzsyRkFHVSwrQkFBK0I7a0JBWjNDLFNBQVM7K0JBRUUsMEJBQTBCLFlBRTFCOzs7OztHQUtULGNBQ1csS0FBSzs4QkFJVixZQUFZO3NCQURsQixZQUFZO3VCQUFDLHdCQUF3QixFQUFFLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKEMpIDIwMTUgVGhlIEdyYXZpdGVlIHRlYW0gKGh0dHA6Ly9ncmF2aXRlZS5pbylcbiAqXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgXCJMaWNlbnNlXCIpO1xuICogeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxuICogWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogICAgICAgICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvTElDRU5TRS0yLjBcbiAqXG4gKiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4gKiBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhbiBcIkFTIElTXCIgQkFTSVMsXG4gKiBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC5cbiAqIFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbiAqIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG5pbXBvcnQgeyBDb21wb25lbnQsIENvbnRlbnRDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBHaW9Nb25hY29FZGl0b3JDb21wb25lbnQgfSBmcm9tICcuL2dpby1tb25hY28tZWRpdG9yLmNvbXBvbmVudCc7XG5cbkBDb21wb25lbnQoe1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQGFuZ3VsYXItZXNsaW50L2NvbXBvbmVudC1zZWxlY3RvclxuICBzZWxlY3RvcjogJ1tnaW9Nb25hY29DbGlwYm9hcmRDb3B5XScsXG4gIHN0eWxlVXJsczogWycuL2dpby1tb25hY28tY2xpcGJvYXJkLWNvcHkuY29tcG9uZW50LnNjc3MnXSxcbiAgdGVtcGxhdGU6IGBcbiAgICA8ZGl2IGNsYXNzPVwiZWRpdG9yLXdyYXBwZXJcIj5cbiAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgICAgIDxnaW8tY2xpcGJvYXJkLWNvcHktaWNvbiBjbGFzcz1cImNvcHktYnRuXCIgW2NvbnRlbnRUb0NvcHldPVwibW9uYWNvRWRpdG9yPy52YWx1ZSA/PyAnJ1wiPjwvZ2lvLWNsaXBib2FyZC1jb3B5LWljb24+XG4gICAgPC9kaXY+XG4gIGAsXG4gIHN0YW5kYWxvbmU6IGZhbHNlLFxufSlcbmV4cG9ydCBjbGFzcyBHaW9Nb25hY29DbGlwYm9hcmRDb3B5Q29tcG9uZW50IHtcbiAgQENvbnRlbnRDaGlsZChHaW9Nb25hY29FZGl0b3JDb21wb25lbnQsIHsgc3RhdGljOiBmYWxzZSB9KVxuICBwdWJsaWMgbW9uYWNvRWRpdG9yOiBHaW9Nb25hY29FZGl0b3JDb21wb25lbnQgfCBudWxsID0gbnVsbDtcbn1cbiJdfQ==
|
|
@@ -13,7 +13,7 @@
|
|
|
13
13
|
* See the License for the specific language governing permissions and
|
|
14
14
|
* limitations under the License.
|
|
15
15
|
*/
|
|
16
|
-
import { ChangeDetectionStrategy, Component, HostBinding, Inject, Input, Optional, Self, } from '@angular/core';
|
|
16
|
+
import { ChangeDetectionStrategy, Component, effect, HostBinding, Inject, Input, Optional, Self, signal, } from '@angular/core';
|
|
17
17
|
import { isEqual, isString, uniqueId } from 'lodash';
|
|
18
18
|
import { ReplaySubject, Subject } from 'rxjs';
|
|
19
19
|
import { takeUntil } from 'rxjs/operators';
|
|
@@ -50,6 +50,10 @@ export class GioMonacoEditorComponent {
|
|
|
50
50
|
this.value = '';
|
|
51
51
|
this.readOnly = false;
|
|
52
52
|
this.toDisposes = [];
|
|
53
|
+
this.isMonacoEditorReady = signal({
|
|
54
|
+
isSetup: false,
|
|
55
|
+
hasFirstValue: false,
|
|
56
|
+
});
|
|
53
57
|
this._onChange = () => ({});
|
|
54
58
|
this._onTouched = () => ({});
|
|
55
59
|
this.unsubscribe$ = new Subject();
|
|
@@ -59,11 +63,22 @@ export class GioMonacoEditorComponent {
|
|
|
59
63
|
this.ngControl.valueAccessor = this;
|
|
60
64
|
}
|
|
61
65
|
this.monacoEditorService.loadEditor();
|
|
66
|
+
effect(() => {
|
|
67
|
+
const { isSetup, hasFirstValue } = this.isMonacoEditorReady();
|
|
68
|
+
if (isSetup && hasFirstValue) {
|
|
69
|
+
if (this.textModel) {
|
|
70
|
+
this.textModel.setValue(this.value);
|
|
71
|
+
}
|
|
72
|
+
this.updateModelLanguage();
|
|
73
|
+
this.autoformatValue();
|
|
74
|
+
}
|
|
75
|
+
});
|
|
62
76
|
}
|
|
63
77
|
ngAfterViewInit() {
|
|
64
78
|
// Wait until monaco editor is available
|
|
65
79
|
this.monacoEditorService.loaded$.pipe(takeUntil(this.unsubscribe$)).subscribe(({ monaco }) => {
|
|
66
80
|
this.setupEditor(monaco);
|
|
81
|
+
this.isMonacoEditorReady.update(({ hasFirstValue }) => ({ isSetup: true, hasFirstValue }));
|
|
67
82
|
this.loaded$.next(false);
|
|
68
83
|
this.changeDetectorRef.detectChanges();
|
|
69
84
|
});
|
|
@@ -85,9 +100,7 @@ export class GioMonacoEditorComponent {
|
|
|
85
100
|
writeValue(_value) {
|
|
86
101
|
if (_value) {
|
|
87
102
|
this.value = isString(_value) ? _value : JSON.stringify(_value);
|
|
88
|
-
|
|
89
|
-
if (this.textModel) {
|
|
90
|
-
this.textModel.setValue(this.value);
|
|
103
|
+
this.isMonacoEditorReady.update(({ isSetup }) => ({ isSetup, hasFirstValue: true }));
|
|
91
104
|
}
|
|
92
105
|
}
|
|
93
106
|
// From ControlValueAccessor interface
|
|
@@ -131,11 +144,6 @@ export class GioMonacoEditorComponent {
|
|
|
131
144
|
this.standaloneCodeEditor = monaco.editor.create(domElement, {
|
|
132
145
|
...options,
|
|
133
146
|
});
|
|
134
|
-
if (!this.disableAutoFormat) {
|
|
135
|
-
setTimeout(() => {
|
|
136
|
-
this.standaloneCodeEditor?.getAction('editor.action.formatDocument')?.run();
|
|
137
|
-
}, 80);
|
|
138
|
-
}
|
|
139
147
|
if (this.singleLineMode) {
|
|
140
148
|
this.standaloneCodeEditor?.addAction({
|
|
141
149
|
id: 'custom.action',
|
|
@@ -246,6 +254,27 @@ export class GioMonacoEditorComponent {
|
|
|
246
254
|
break;
|
|
247
255
|
}
|
|
248
256
|
}
|
|
257
|
+
updateModelLanguage() {
|
|
258
|
+
const languageId = this.languageConfig?.language ?? (isJsonString(this.value) ? 'json' : 'plaintext');
|
|
259
|
+
if (this.textModel && window.monaco) {
|
|
260
|
+
window.monaco.editor.setModelLanguage(this.textModel, languageId);
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
autoformatValue() {
|
|
264
|
+
if (!this.disableAutoFormat) {
|
|
265
|
+
setTimeout(() => {
|
|
266
|
+
const previousReadOnlyState = this.options.readOnly || this.readOnly;
|
|
267
|
+
this.standaloneCodeEditor?.updateOptions({ readOnly: false });
|
|
268
|
+
this.standaloneCodeEditor
|
|
269
|
+
?.getAction('editor.action.formatDocument')
|
|
270
|
+
?.run()
|
|
271
|
+
.finally(() => {
|
|
272
|
+
this.standaloneCodeEditor?.updateOptions({ readOnly: previousReadOnlyState });
|
|
273
|
+
this.changeDetectorRef.detectChanges();
|
|
274
|
+
});
|
|
275
|
+
}, 80);
|
|
276
|
+
}
|
|
277
|
+
}
|
|
249
278
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.4", ngImport: i0, type: GioMonacoEditorComponent, deps: [{ token: i0.ElementRef }, { token: GIO_MONACO_EDITOR_CONFIG }, { token: i1.GioMonacoEditorService }, { token: i2.GioLanguageJsonService }, { token: i3.GioLanguageElService }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: i4.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
250
279
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.4", type: GioMonacoEditorComponent, isStandalone: false, selector: "gio-monaco-editor", inputs: { languageConfig: "languageConfig", options: "options", disableMiniMap: "disableMiniMap", disableAutoFormat: "disableAutoFormat", singleLineMode: "singleLineMode" }, host: { properties: { "class.single-line": "this.singleLineMode" } }, ngImport: i0, template: ` <div *ngIf="loaded$ | async">Loading...</div>`, isInline: true, styles: [":host{display:block;height:100%;min-height:150px;pointer-events:auto;transition:opacity .2s ease-out}:host.single-line{display:flex;height:24px;min-height:24px;align-items:center}:host-context(.hidden){opacity:0}\n"], dependencies: [{ kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
251
280
|
}
|
|
@@ -282,4 +311,4 @@ const isJsonString = (str) => {
|
|
|
282
311
|
}
|
|
283
312
|
return true;
|
|
284
313
|
};
|
|
285
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gio-monaco-editor.component.js","sourceRoot":"","sources":["../../../../../projects/ui-particles-angular/src/lib/gio-monaco-editor/gio-monaco-editor.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (C) 2023 The Gravitee team (http://gravitee.io)\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *         http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  Optional,\n  Self,\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { isEqual, isString, uniqueId } from 'lodash';\nimport Monaco, { editor } from 'monaco-editor';\nimport { ReplaySubject, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { GIO_MONACO_EDITOR_CONFIG, GioMonacoEditorConfig } from './models/GioMonacoEditorConfig';\nimport { GioLanguageJsonService } from './services/gio-language-json.service';\nimport { GioMonacoEditorService } from './services/gio-monaco-editor.service';\nimport { GioLanguageElService } from './services/gio-language-el.service';\nimport { JSONSchema } from './models/JSONSchemaAutoComplete';\n\nexport type MonacoEditorLanguageConfig =\n  | {\n      language: 'json';\n      schemas?: { uri: string; schema: unknown }[];\n    }\n  | {\n      language: 'markdown';\n    }\n  | {\n      language: 'html';\n    }\n  | {\n      language: 'yaml';\n    }\n  | {\n      language: 'spel';\n      schema?: JSONSchema;\n    }\n  | {\n      language: 'css';\n    };\n\n@Component({\n  selector: 'gio-monaco-editor',\n  template: ` <div *ngIf=\"loaded$ | async\">Loading...</div>`,\n  styleUrls: ['./gio-monaco-editor.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: false,\n})\nexport class GioMonacoEditorComponent implements ControlValueAccessor, AfterViewInit, OnDestroy {\n  @Input()\n  public languageConfig?: MonacoEditorLanguageConfig;\n\n  @Input()\n  public options: editor.IStandaloneEditorConstructionOptions = {};\n\n  @Input()\n  public disableMiniMap = false;\n\n  @Input()\n  public disableAutoFormat = false;\n\n  @Input()\n  @HostBinding('class.single-line')\n  public singleLineMode = false;\n\n  public loaded$ = new ReplaySubject<boolean>(1);\n\n  private defaultOptions: editor.IStandaloneEditorConstructionOptions = {\n    contextmenu: false,\n    minimap: {\n      enabled: true,\n    },\n    automaticLayout: true,\n    scrollBeyondLastLine: false,\n  };\n\n  public value = '';\n  public readOnly = false;\n  public standaloneCodeEditor?: editor.IStandaloneCodeEditor;\n  private textModel?: editor.ITextModel;\n  private toDisposes: Monaco.IDisposable[] = [];\n\n  protected _onChange: (_value: string | null) => void = () => ({});\n\n  protected _onTouched: () => void = () => ({});\n  private unsubscribe$ = new Subject<void>();\n\n  constructor(\n    public readonly hostElement: ElementRef,\n    @Inject(GIO_MONACO_EDITOR_CONFIG) private readonly config: GioMonacoEditorConfig,\n    private readonly monacoEditorService: GioMonacoEditorService,\n    private readonly languageJsonService: GioLanguageJsonService,\n    private readonly languageSpelService: GioLanguageElService,\n    private readonly changeDetectorRef: ChangeDetectorRef,\n    private readonly ngZone: NgZone,\n    @Optional() @Self() public readonly ngControl: NgControl,\n  ) {\n    if (this.ngControl) {\n      // Set the value accessor directly (instead of providing\n      // NG_VALUE_ACCESSOR) to avoid running into a circular import\n      this.ngControl.valueAccessor = this;\n    }\n    this.monacoEditorService.loadEditor();\n  }\n\n  public ngAfterViewInit() {\n    // Wait until monaco editor is available\n    this.monacoEditorService.loaded$.pipe(takeUntil(this.unsubscribe$)).subscribe(({ monaco }) => {\n      this.setupEditor(monaco);\n\n      this.loaded$.next(false);\n      this.changeDetectorRef.detectChanges();\n    });\n  }\n\n  public ngOnDestroy() {\n    this.toDisposes.forEach(d => d.dispose());\n\n    if (this.standaloneCodeEditor) {\n      this.standaloneCodeEditor.dispose();\n      this.standaloneCodeEditor = undefined;\n    }\n\n    if (this.textModel) {\n      this.textModel.dispose();\n      this.textModel = undefined;\n    }\n    this.unsubscribe$.next();\n    this.unsubscribe$.complete();\n  }\n\n  // From ControlValueAccessor interface\n  public writeValue(_value: string): void {\n    if (_value) {\n      this.value = isString(_value) ? _value : JSON.stringify(_value);\n    }\n    if (this.textModel) {\n      this.textModel.setValue(this.value);\n    }\n  }\n\n  // From ControlValueAccessor interface\n  public registerOnChange(fn: (_value: string | null) => void): void {\n    this._onChange = fn;\n  }\n\n  // From ControlValueAccessor interface\n  public registerOnTouched(fn: () => void): void {\n    this._onTouched = fn;\n  }\n\n  // From ControlValueAccessor interface\n  public setDisabledState(isDisabled: boolean): void {\n    this.readOnly = isDisabled;\n\n    if (this.standaloneCodeEditor) {\n      this.standaloneCodeEditor.updateOptions({\n        readOnly: isDisabled,\n      });\n    }\n  }\n\n  private setupEditor(monaco: typeof Monaco) {\n    if (!this.hostElement) {\n      throw new Error('No editor ref found.');\n    }\n\n    const domElement = this.hostElement.nativeElement;\n\n    const settings = {\n      value: this.value,\n      language: this.languageConfig?.language ?? (isJsonString(this.value) ? 'json' : 'plaintext'),\n      uri: `code-${uniqueId()}`,\n    };\n\n    this.ngZone.runOutsideAngular(() => {\n      this.textModel = monaco.editor.createModel(settings.value, settings.language, monaco.Uri.parse(settings.uri));\n    });\n\n    const options = Object.assign({}, this.defaultOptions, this.options, {\n      readOnly: !this.ngControl && 'readOnly' in this.options ? this.options.readOnly : this.readOnly,\n      theme: this.config.theme ?? 'vs',\n      model: this.textModel,\n      minimap: {\n        enabled: !this.disableMiniMap,\n      },\n    });\n\n    this.standaloneCodeEditor = monaco.editor.create(domElement, {\n      ...options,\n    });\n\n    if (!this.disableAutoFormat) {\n      setTimeout(() => {\n        this.standaloneCodeEditor?.getAction('editor.action.formatDocument')?.run();\n      }, 80);\n    }\n\n    if (this.singleLineMode) {\n      this.standaloneCodeEditor?.addAction({\n        id: 'custom.action',\n        label: 'custom action',\n        keybindings: [monaco.KeyCode.Enter],\n        precondition: '!suggestWidgetVisible && !renameInputVisible && !inSnippetMode && !quickFixWidgetVisible',\n        run: () => {\n          // Ignore Enter key in single line mode when writing\n          return;\n        },\n      });\n    }\n\n    const onDidChangeContent = this.textModel?.onDidChangeContent(() => {\n      const textModelValue = this.textModel?.getValue() ?? '';\n      if (this.singleLineMode) {\n        // If value has \\n, \\r or \\r\\n, remove them\n        // Useful to clear line breaks when pasting text\n        const hasLineBreak = new RegExp(/(\\r\\n|\\n|\\r)/gm);\n        if (hasLineBreak.test(textModelValue)) {\n          const currentPosition = this.standaloneCodeEditor?.getPosition();\n          setTimeout(() => {\n            this.standaloneCodeEditor?.pushUndoStop();\n            this.textModel?.setValue(textModelValue.replace(/(\\r\\n|\\n|\\r)/gm, ''));\n            if (currentPosition) {\n              this.standaloneCodeEditor?.setPosition(currentPosition);\n            }\n            this.standaloneCodeEditor?.popUndoStop();\n          }, 0);\n          return;\n        }\n      }\n\n      this.ngZone.run(() => {\n        if (!this.readOnly && !isEqual(this.value, textModelValue)) {\n          setTimeout(() => {\n            this.value = textModelValue;\n            this._onChange(textModelValue);\n            this._onTouched();\n          }, 0);\n        }\n      });\n    });\n\n    if (this.singleLineMode) {\n      // Source : https://farzadyz.com/blog/single-line-monaco-editor\n      this.standaloneCodeEditor?.updateOptions({\n        // quickSuggestions: false,\n        fixedOverflowWidgets: true,\n        acceptSuggestionOnEnter: 'on',\n        hover: {\n          delay: 100,\n        },\n        roundedSelection: false,\n        contextmenu: false,\n        cursorStyle: 'line-thin',\n        links: false,\n        find: {\n          addExtraSpaceOnTop: false,\n          autoFindInSelection: 'never',\n          seedSearchStringFromSelection: 'never',\n        },\n        fontSize: 14,\n        fontWeight: 'normal',\n        overviewRulerLanes: 0,\n        scrollBeyondLastColumn: 0,\n        wordWrap: 'on',\n        minimap: {\n          enabled: false,\n        },\n        lineNumbers: 'off',\n        hideCursorInOverviewRuler: true,\n        overviewRulerBorder: false,\n        glyphMargin: false,\n        folding: false,\n        lineDecorationsWidth: 0,\n        lineNumbersMinChars: 0,\n        renderLineHighlight: 'none',\n        scrollbar: {\n          horizontal: 'hidden',\n          vertical: 'hidden',\n          alwaysConsumeMouseWheel: false,\n        },\n      });\n    }\n\n    const onDidBlurEditorWidget = this.standaloneCodeEditor?.onDidBlurEditorWidget(() => {\n      this.ngZone.run(() => {\n        if (!this.readOnly) this._onTouched();\n      });\n    });\n\n    this.toDisposes = [onDidChangeContent, onDidBlurEditorWidget].filter(d => !!d) as Monaco.IDisposable[];\n\n    this.setupLanguage(settings.uri, this.languageConfig);\n  }\n\n  private setupLanguage(uri: string, languageConfig?: MonacoEditorLanguageConfig) {\n    if (!languageConfig) {\n      return;\n    }\n\n    switch (languageConfig.language) {\n      case 'json':\n        if (languageConfig.schemas) {\n          this.languageJsonService.addSchemas(uri, languageConfig.schemas);\n        }\n        break;\n      case 'spel':\n        if (languageConfig.schema) {\n          this.languageSpelService.setSchema(languageConfig.schema);\n        }\n        break;\n      default:\n        break;\n    }\n  }\n}\n\nconst isJsonString = (str: string): boolean => {\n  try {\n    JSON.parse(str);\n  } catch (e) {\n    return false;\n  }\n  return true;\n};\n"]}
|
|
314
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gio-monaco-editor.component.js","sourceRoot":"","sources":["../../../../../projects/ui-particles-angular/src/lib/gio-monaco-editor/gio-monaco-editor.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (C) 2023 The Gravitee team (http://gravitee.io)\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *         http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  effect,\n  ElementRef,\n  HostBinding,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  Optional,\n  Self,\n  signal,\n  WritableSignal,\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { isEqual, isString, uniqueId } from 'lodash';\nimport Monaco, { editor } from 'monaco-editor';\nimport { ReplaySubject, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { GIO_MONACO_EDITOR_CONFIG, GioMonacoEditorConfig } from './models/GioMonacoEditorConfig';\nimport { GioLanguageJsonService } from './services/gio-language-json.service';\nimport { GioMonacoEditorService } from './services/gio-monaco-editor.service';\nimport { GioLanguageElService } from './services/gio-language-el.service';\nimport { JSONSchema } from './models/JSONSchemaAutoComplete';\n\nexport type MonacoEditorLanguageConfig =\n  | {\n      language: 'json';\n      schemas?: { uri: string; schema: unknown }[];\n    }\n  | {\n      language: 'markdown';\n    }\n  | {\n      language: 'html';\n    }\n  | {\n      language: 'yaml';\n    }\n  | {\n      language: 'spel';\n      schema?: JSONSchema;\n    }\n  | {\n      language: 'css';\n    };\n\n@Component({\n  selector: 'gio-monaco-editor',\n  template: ` <div *ngIf=\"loaded$ | async\">Loading...</div>`,\n  styleUrls: ['./gio-monaco-editor.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: false,\n})\nexport class GioMonacoEditorComponent implements ControlValueAccessor, AfterViewInit, OnDestroy {\n  @Input()\n  public languageConfig?: MonacoEditorLanguageConfig;\n\n  @Input()\n  public options: editor.IStandaloneEditorConstructionOptions = {};\n\n  @Input()\n  public disableMiniMap = false;\n\n  @Input()\n  public disableAutoFormat = false;\n\n  @Input()\n  @HostBinding('class.single-line')\n  public singleLineMode = false;\n\n  public loaded$ = new ReplaySubject<boolean>(1);\n\n  private defaultOptions: editor.IStandaloneEditorConstructionOptions = {\n    contextmenu: false,\n    minimap: {\n      enabled: true,\n    },\n    automaticLayout: true,\n    scrollBeyondLastLine: false,\n  };\n\n  public value = '';\n  public readOnly = false;\n  public standaloneCodeEditor?: editor.IStandaloneCodeEditor;\n  private textModel?: editor.ITextModel;\n  private toDisposes: Monaco.IDisposable[] = [];\n\n  private isMonacoEditorReady: WritableSignal<{ isSetup: boolean; hasFirstValue: boolean }> = signal({\n    isSetup: false,\n    hasFirstValue: false,\n  });\n\n  protected _onChange: (_value: string | null) => void = () => ({});\n\n  protected _onTouched: () => void = () => ({});\n  private unsubscribe$ = new Subject<void>();\n\n  constructor(\n    public readonly hostElement: ElementRef,\n    @Inject(GIO_MONACO_EDITOR_CONFIG) private readonly config: GioMonacoEditorConfig,\n    private readonly monacoEditorService: GioMonacoEditorService,\n    private readonly languageJsonService: GioLanguageJsonService,\n    private readonly languageSpelService: GioLanguageElService,\n    private readonly changeDetectorRef: ChangeDetectorRef,\n    private readonly ngZone: NgZone,\n    @Optional() @Self() public readonly ngControl: NgControl,\n  ) {\n    if (this.ngControl) {\n      // Set the value accessor directly (instead of providing\n      // NG_VALUE_ACCESSOR) to avoid running into a circular import\n      this.ngControl.valueAccessor = this;\n    }\n    this.monacoEditorService.loadEditor();\n\n    effect(() => {\n      const { isSetup, hasFirstValue } = this.isMonacoEditorReady();\n      if (isSetup && hasFirstValue) {\n        if (this.textModel) {\n          this.textModel.setValue(this.value);\n        }\n\n        this.updateModelLanguage();\n        this.autoformatValue();\n      }\n    });\n  }\n\n  public ngAfterViewInit() {\n    // Wait until monaco editor is available\n    this.monacoEditorService.loaded$.pipe(takeUntil(this.unsubscribe$)).subscribe(({ monaco }) => {\n      this.setupEditor(monaco);\n      this.isMonacoEditorReady.update(({ hasFirstValue }) => ({ isSetup: true, hasFirstValue }));\n\n      this.loaded$.next(false);\n      this.changeDetectorRef.detectChanges();\n    });\n  }\n\n  public ngOnDestroy() {\n    this.toDisposes.forEach(d => d.dispose());\n\n    if (this.standaloneCodeEditor) {\n      this.standaloneCodeEditor.dispose();\n      this.standaloneCodeEditor = undefined;\n    }\n\n    if (this.textModel) {\n      this.textModel.dispose();\n      this.textModel = undefined;\n    }\n    this.unsubscribe$.next();\n    this.unsubscribe$.complete();\n  }\n\n  // From ControlValueAccessor interface\n  public writeValue(_value: string | null): void {\n    if (_value) {\n      this.value = isString(_value) ? _value : JSON.stringify(_value);\n      this.isMonacoEditorReady.update(({ isSetup }) => ({ isSetup, hasFirstValue: true }));\n    }\n  }\n\n  // From ControlValueAccessor interface\n  public registerOnChange(fn: (_value: string | null) => void): void {\n    this._onChange = fn;\n  }\n\n  // From ControlValueAccessor interface\n  public registerOnTouched(fn: () => void): void {\n    this._onTouched = fn;\n  }\n\n  // From ControlValueAccessor interface\n  public setDisabledState(isDisabled: boolean): void {\n    this.readOnly = isDisabled;\n\n    if (this.standaloneCodeEditor) {\n      this.standaloneCodeEditor.updateOptions({\n        readOnly: isDisabled,\n      });\n    }\n  }\n\n  private setupEditor(monaco: typeof Monaco) {\n    if (!this.hostElement) {\n      throw new Error('No editor ref found.');\n    }\n\n    const domElement = this.hostElement.nativeElement;\n\n    const settings = {\n      value: this.value,\n      language: this.languageConfig?.language ?? (isJsonString(this.value) ? 'json' : 'plaintext'),\n      uri: `code-${uniqueId()}`,\n    };\n\n    this.ngZone.runOutsideAngular(() => {\n      this.textModel = monaco.editor.createModel(settings.value, settings.language, monaco.Uri.parse(settings.uri));\n    });\n\n    const options = Object.assign({}, this.defaultOptions, this.options, {\n      readOnly: !this.ngControl && 'readOnly' in this.options ? this.options.readOnly : this.readOnly,\n      theme: this.config.theme ?? 'vs',\n      model: this.textModel,\n      minimap: {\n        enabled: !this.disableMiniMap,\n      },\n    });\n\n    this.standaloneCodeEditor = monaco.editor.create(domElement, {\n      ...options,\n    });\n\n    if (this.singleLineMode) {\n      this.standaloneCodeEditor?.addAction({\n        id: 'custom.action',\n        label: 'custom action',\n        keybindings: [monaco.KeyCode.Enter],\n        precondition: '!suggestWidgetVisible && !renameInputVisible && !inSnippetMode && !quickFixWidgetVisible',\n        run: () => {\n          // Ignore Enter key in single line mode when writing\n          return;\n        },\n      });\n    }\n\n    const onDidChangeContent = this.textModel?.onDidChangeContent(() => {\n      const textModelValue = this.textModel?.getValue() ?? '';\n      if (this.singleLineMode) {\n        // If value has \\n, \\r or \\r\\n, remove them\n        // Useful to clear line breaks when pasting text\n        const hasLineBreak = new RegExp(/(\\r\\n|\\n|\\r)/gm);\n        if (hasLineBreak.test(textModelValue)) {\n          const currentPosition = this.standaloneCodeEditor?.getPosition();\n          setTimeout(() => {\n            this.standaloneCodeEditor?.pushUndoStop();\n            this.textModel?.setValue(textModelValue.replace(/(\\r\\n|\\n|\\r)/gm, ''));\n            if (currentPosition) {\n              this.standaloneCodeEditor?.setPosition(currentPosition);\n            }\n            this.standaloneCodeEditor?.popUndoStop();\n          }, 0);\n          return;\n        }\n      }\n\n      this.ngZone.run(() => {\n        if (!this.readOnly && !isEqual(this.value, textModelValue)) {\n          setTimeout(() => {\n            this.value = textModelValue;\n            this._onChange(textModelValue);\n            this._onTouched();\n          }, 0);\n        }\n      });\n    });\n\n    if (this.singleLineMode) {\n      // Source : https://farzadyz.com/blog/single-line-monaco-editor\n      this.standaloneCodeEditor?.updateOptions({\n        // quickSuggestions: false,\n        fixedOverflowWidgets: true,\n        acceptSuggestionOnEnter: 'on',\n        hover: {\n          delay: 100,\n        },\n        roundedSelection: false,\n        contextmenu: false,\n        cursorStyle: 'line-thin',\n        links: false,\n        find: {\n          addExtraSpaceOnTop: false,\n          autoFindInSelection: 'never',\n          seedSearchStringFromSelection: 'never',\n        },\n        fontSize: 14,\n        fontWeight: 'normal',\n        overviewRulerLanes: 0,\n        scrollBeyondLastColumn: 0,\n        wordWrap: 'on',\n        minimap: {\n          enabled: false,\n        },\n        lineNumbers: 'off',\n        hideCursorInOverviewRuler: true,\n        overviewRulerBorder: false,\n        glyphMargin: false,\n        folding: false,\n        lineDecorationsWidth: 0,\n        lineNumbersMinChars: 0,\n        renderLineHighlight: 'none',\n        scrollbar: {\n          horizontal: 'hidden',\n          vertical: 'hidden',\n          alwaysConsumeMouseWheel: false,\n        },\n      });\n    }\n\n    const onDidBlurEditorWidget = this.standaloneCodeEditor?.onDidBlurEditorWidget(() => {\n      this.ngZone.run(() => {\n        if (!this.readOnly) this._onTouched();\n      });\n    });\n\n    this.toDisposes = [onDidChangeContent, onDidBlurEditorWidget].filter(d => !!d) as Monaco.IDisposable[];\n\n    this.setupLanguage(settings.uri, this.languageConfig);\n  }\n\n  private setupLanguage(uri: string, languageConfig?: MonacoEditorLanguageConfig) {\n    if (!languageConfig) {\n      return;\n    }\n\n    switch (languageConfig.language) {\n      case 'json':\n        if (languageConfig.schemas) {\n          this.languageJsonService.addSchemas(uri, languageConfig.schemas);\n        }\n        break;\n      case 'spel':\n        if (languageConfig.schema) {\n          this.languageSpelService.setSchema(languageConfig.schema);\n        }\n        break;\n      default:\n        break;\n    }\n  }\n\n  private updateModelLanguage() {\n    const languageId = this.languageConfig?.language ?? (isJsonString(this.value) ? 'json' : 'plaintext');\n    if (this.textModel && window.monaco) {\n      window.monaco.editor.setModelLanguage(this.textModel, languageId);\n    }\n  }\n\n  private autoformatValue() {\n    if (!this.disableAutoFormat) {\n      setTimeout(() => {\n        const previousReadOnlyState = this.options.readOnly || this.readOnly;\n        this.standaloneCodeEditor?.updateOptions({ readOnly: false });\n        this.standaloneCodeEditor\n          ?.getAction('editor.action.formatDocument')\n          ?.run()\n          .finally(() => {\n            this.standaloneCodeEditor?.updateOptions({ readOnly: previousReadOnlyState });\n            this.changeDetectorRef.detectChanges();\n          });\n      }, 80);\n    }\n  }\n}\n\nconst isJsonString = (str: string): boolean => {\n  try {\n    JSON.parse(str);\n  } catch (e) {\n    return false;\n  }\n  return true;\n};\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { trigger, transition, style, animate } from '@angular/animations';
|
|
2
2
|
import * as i0 from '@angular/core';
|
|
3
|
-
import { EventEmitter, Component, HostBinding, Input, Output, HostListener, NgModule, ChangeDetectionStrategy, Optional, Self, ViewChild, Directive, Injector, Inject, forwardRef, ContentChildren, Injectable, Host, ContentChild, InjectionToken, inject,
|
|
3
|
+
import { EventEmitter, Component, HostBinding, Input, Output, HostListener, NgModule, ChangeDetectionStrategy, Optional, Self, ViewChild, Directive, Injector, Inject, forwardRef, ContentChildren, Injectable, Host, ContentChild, InjectionToken, inject, signal, effect, ViewContainerRef, computed, Pipe, ViewEncapsulation } from '@angular/core';
|
|
4
4
|
import { of, Subject, fromEvent, ReplaySubject, merge, Observable, BehaviorSubject, timer } from 'rxjs';
|
|
5
5
|
import { delay, tap, startWith, switchMap, map, distinctUntilChanged, takeUntil, filter, take, debounceTime, shareReplay, catchError, debounce } from 'rxjs/operators';
|
|
6
6
|
import * as i1 from '@angular/common';
|
|
@@ -3622,6 +3622,10 @@ class GioMonacoEditorComponent {
|
|
|
3622
3622
|
this.value = '';
|
|
3623
3623
|
this.readOnly = false;
|
|
3624
3624
|
this.toDisposes = [];
|
|
3625
|
+
this.isMonacoEditorReady = signal({
|
|
3626
|
+
isSetup: false,
|
|
3627
|
+
hasFirstValue: false,
|
|
3628
|
+
});
|
|
3625
3629
|
this._onChange = () => ({});
|
|
3626
3630
|
this._onTouched = () => ({});
|
|
3627
3631
|
this.unsubscribe$ = new Subject();
|
|
@@ -3631,11 +3635,22 @@ class GioMonacoEditorComponent {
|
|
|
3631
3635
|
this.ngControl.valueAccessor = this;
|
|
3632
3636
|
}
|
|
3633
3637
|
this.monacoEditorService.loadEditor();
|
|
3638
|
+
effect(() => {
|
|
3639
|
+
const { isSetup, hasFirstValue } = this.isMonacoEditorReady();
|
|
3640
|
+
if (isSetup && hasFirstValue) {
|
|
3641
|
+
if (this.textModel) {
|
|
3642
|
+
this.textModel.setValue(this.value);
|
|
3643
|
+
}
|
|
3644
|
+
this.updateModelLanguage();
|
|
3645
|
+
this.autoformatValue();
|
|
3646
|
+
}
|
|
3647
|
+
});
|
|
3634
3648
|
}
|
|
3635
3649
|
ngAfterViewInit() {
|
|
3636
3650
|
// Wait until monaco editor is available
|
|
3637
3651
|
this.monacoEditorService.loaded$.pipe(takeUntil(this.unsubscribe$)).subscribe(({ monaco }) => {
|
|
3638
3652
|
this.setupEditor(monaco);
|
|
3653
|
+
this.isMonacoEditorReady.update(({ hasFirstValue }) => ({ isSetup: true, hasFirstValue }));
|
|
3639
3654
|
this.loaded$.next(false);
|
|
3640
3655
|
this.changeDetectorRef.detectChanges();
|
|
3641
3656
|
});
|
|
@@ -3657,9 +3672,7 @@ class GioMonacoEditorComponent {
|
|
|
3657
3672
|
writeValue(_value) {
|
|
3658
3673
|
if (_value) {
|
|
3659
3674
|
this.value = isString(_value) ? _value : JSON.stringify(_value);
|
|
3660
|
-
|
|
3661
|
-
if (this.textModel) {
|
|
3662
|
-
this.textModel.setValue(this.value);
|
|
3675
|
+
this.isMonacoEditorReady.update(({ isSetup }) => ({ isSetup, hasFirstValue: true }));
|
|
3663
3676
|
}
|
|
3664
3677
|
}
|
|
3665
3678
|
// From ControlValueAccessor interface
|
|
@@ -3703,11 +3716,6 @@ class GioMonacoEditorComponent {
|
|
|
3703
3716
|
this.standaloneCodeEditor = monaco.editor.create(domElement, {
|
|
3704
3717
|
...options,
|
|
3705
3718
|
});
|
|
3706
|
-
if (!this.disableAutoFormat) {
|
|
3707
|
-
setTimeout(() => {
|
|
3708
|
-
this.standaloneCodeEditor?.getAction('editor.action.formatDocument')?.run();
|
|
3709
|
-
}, 80);
|
|
3710
|
-
}
|
|
3711
3719
|
if (this.singleLineMode) {
|
|
3712
3720
|
this.standaloneCodeEditor?.addAction({
|
|
3713
3721
|
id: 'custom.action',
|
|
@@ -3818,6 +3826,27 @@ class GioMonacoEditorComponent {
|
|
|
3818
3826
|
break;
|
|
3819
3827
|
}
|
|
3820
3828
|
}
|
|
3829
|
+
updateModelLanguage() {
|
|
3830
|
+
const languageId = this.languageConfig?.language ?? (isJsonString(this.value) ? 'json' : 'plaintext');
|
|
3831
|
+
if (this.textModel && window.monaco) {
|
|
3832
|
+
window.monaco.editor.setModelLanguage(this.textModel, languageId);
|
|
3833
|
+
}
|
|
3834
|
+
}
|
|
3835
|
+
autoformatValue() {
|
|
3836
|
+
if (!this.disableAutoFormat) {
|
|
3837
|
+
setTimeout(() => {
|
|
3838
|
+
const previousReadOnlyState = this.options.readOnly || this.readOnly;
|
|
3839
|
+
this.standaloneCodeEditor?.updateOptions({ readOnly: false });
|
|
3840
|
+
this.standaloneCodeEditor
|
|
3841
|
+
?.getAction('editor.action.formatDocument')
|
|
3842
|
+
?.run()
|
|
3843
|
+
.finally(() => {
|
|
3844
|
+
this.standaloneCodeEditor?.updateOptions({ readOnly: previousReadOnlyState });
|
|
3845
|
+
this.changeDetectorRef.detectChanges();
|
|
3846
|
+
});
|
|
3847
|
+
}, 80);
|
|
3848
|
+
}
|
|
3849
|
+
}
|
|
3821
3850
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.4", ngImport: i0, type: GioMonacoEditorComponent, deps: [{ token: i0.ElementRef }, { token: GIO_MONACO_EDITOR_CONFIG }, { token: GioMonacoEditorService }, { token: GioLanguageJsonService }, { token: GioLanguageElService }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: i1$2.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
3822
3851
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.4", type: GioMonacoEditorComponent, isStandalone: false, selector: "gio-monaco-editor", inputs: { languageConfig: "languageConfig", options: "options", disableMiniMap: "disableMiniMap", disableAutoFormat: "disableAutoFormat", singleLineMode: "singleLineMode" }, host: { properties: { "class.single-line": "this.singleLineMode" } }, ngImport: i0, template: ` <div *ngIf="loaded$ | async">Loading...</div>`, isInline: true, styles: [":host{display:block;height:100%;min-height:150px;pointer-events:auto;transition:opacity .2s ease-out}:host.single-line{display:flex;height:24px;min-height:24px;align-items:center}:host-context(.hidden){opacity:0}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
3823
3852
|
}
|
|
@@ -4013,23 +4042,29 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.4", ngImpor
|
|
|
4013
4042
|
* limitations under the License.
|
|
4014
4043
|
*/
|
|
4015
4044
|
class GioMonacoClipboardCopyComponent {
|
|
4045
|
+
constructor() {
|
|
4046
|
+
this.monacoEditor = null;
|
|
4047
|
+
}
|
|
4016
4048
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.4", ngImport: i0, type: GioMonacoClipboardCopyComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
4017
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.4", type: GioMonacoClipboardCopyComponent, isStandalone: false, selector: "[gioMonacoClipboardCopy]", ngImport: i0, template: `
|
|
4049
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.4", type: GioMonacoClipboardCopyComponent, isStandalone: false, selector: "[gioMonacoClipboardCopy]", queries: [{ propertyName: "monacoEditor", first: true, predicate: GioMonacoEditorComponent, descendants: true }], ngImport: i0, template: `
|
|
4018
4050
|
<div class="editor-wrapper">
|
|
4019
4051
|
<ng-content></ng-content>
|
|
4020
|
-
<gio-clipboard-copy-icon class="copy-btn"></gio-clipboard-copy-icon>
|
|
4052
|
+
<gio-clipboard-copy-icon class="copy-btn" [contentToCopy]="monacoEditor?.value ?? ''"></gio-clipboard-copy-icon>
|
|
4021
4053
|
</div>
|
|
4022
|
-
`, isInline: true, styles: [".editor-wrapper{position:relative;overflow:auto;
|
|
4054
|
+
`, isInline: true, styles: [".editor-wrapper{position:relative;overflow:auto;flex:1 1 50%}.copy-btn{position:absolute;z-index:10;top:8px;right:8px}\n"], dependencies: [{ kind: "component", type: GioClipboardCopyIconComponent, selector: "gio-clipboard-copy-icon" }] }); }
|
|
4023
4055
|
}
|
|
4024
4056
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.4", ngImport: i0, type: GioMonacoClipboardCopyComponent, decorators: [{
|
|
4025
4057
|
type: Component,
|
|
4026
4058
|
args: [{ selector: '[gioMonacoClipboardCopy]', template: `
|
|
4027
4059
|
<div class="editor-wrapper">
|
|
4028
4060
|
<ng-content></ng-content>
|
|
4029
|
-
<gio-clipboard-copy-icon class="copy-btn"></gio-clipboard-copy-icon>
|
|
4061
|
+
<gio-clipboard-copy-icon class="copy-btn" [contentToCopy]="monacoEditor?.value ?? ''"></gio-clipboard-copy-icon>
|
|
4030
4062
|
</div>
|
|
4031
|
-
`, standalone: false, styles: [".editor-wrapper{position:relative;overflow:auto;
|
|
4032
|
-
}]
|
|
4063
|
+
`, standalone: false, styles: [".editor-wrapper{position:relative;overflow:auto;flex:1 1 50%}.copy-btn{position:absolute;z-index:10;top:8px;right:8px}\n"] }]
|
|
4064
|
+
}], propDecorators: { monacoEditor: [{
|
|
4065
|
+
type: ContentChild,
|
|
4066
|
+
args: [GioMonacoEditorComponent, { static: false }]
|
|
4067
|
+
}] } });
|
|
4033
4068
|
|
|
4034
4069
|
/*
|
|
4035
4070
|
* Copyright (C) 2015 The Gravitee team (http://gravitee.io)
|