@dotglitch/ngx-common 1.0.42 → 1.0.44
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/components/vscode/vscode.component.d.ts +1 -5
- package/esm2020/components/vscode/vscode.component.mjs +49 -50
- package/fesm2015/dotglitch-ngx-common.mjs +49 -50
- package/fesm2015/dotglitch-ngx-common.mjs.map +1 -1
- package/fesm2020/dotglitch-ngx-common.mjs +49 -50
- package/fesm2020/dotglitch-ngx-common.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -44,13 +44,9 @@ export declare class VscodeComponent implements AfterViewInit, OnDestroy {
|
|
|
44
44
|
ngOnDestroy(): void;
|
|
45
45
|
private createEditor;
|
|
46
46
|
private configureLanguageSupport;
|
|
47
|
-
/**
|
|
48
|
-
* true if the monaco UMD files are injected into the webpage
|
|
49
|
-
*/
|
|
50
|
-
private static isMonacoInstalled;
|
|
51
|
-
private installMonaco;
|
|
52
47
|
download(): void;
|
|
53
48
|
resize: () => void;
|
|
54
49
|
static ɵfac: i0.ɵɵFactoryDeclaration<VscodeComponent, never>;
|
|
55
50
|
static ɵcmp: i0.ɵɵComponentDeclaration<VscodeComponent, "app-vscode", never, { "code": "code"; "customLanguage": "customLanguage"; "language": "language"; "installationLocation": "installationLocation"; "tabSize": "tabSize"; "readOnly": "readOnly"; "theme": "theme"; "fontFamily": "fontFamily"; "fontSize": "fontSize"; "automaticLayout": "automaticLayout"; "colorDecorators": "colorDecorators"; "folding": "folding"; "minimapEnabled": "minimapEnabled"; "minimap": "minimap"; "scrollbar": "scrollbar"; "smoothScrolling": "smoothScrolling"; "mouseWheelScrollSensitivity": "mouseWheelScrollSensitivity"; "scrollBeyondLastLine": "scrollBeyondLastLine"; "scrollBeyondLastColumn": "scrollBeyondLastColumn"; "lineNumbers": "lineNumbers"; "restSettings": "restSettings"; }, { "codeChange": "codeChange"; }, never, never, true, never>;
|
|
56
51
|
}
|
|
52
|
+
export declare const InstallMonacoUMD: (path?: string) => Promise<any>;
|
|
@@ -75,7 +75,7 @@ export class VscodeComponent {
|
|
|
75
75
|
this.resize = () => {
|
|
76
76
|
this.editor?.layout();
|
|
77
77
|
};
|
|
78
|
-
this.
|
|
78
|
+
InstallMonacoUMD(this.installationLocation);
|
|
79
79
|
this._sub = this.typeDebounce.subscribe(t => {
|
|
80
80
|
this.codeChange.next(this._code = this.editor.getValue());
|
|
81
81
|
});
|
|
@@ -92,21 +92,7 @@ export class VscodeComponent {
|
|
|
92
92
|
Monaco?.editor.setTheme(this.theme);
|
|
93
93
|
}
|
|
94
94
|
async ngAfterViewInit() {
|
|
95
|
-
await
|
|
96
|
-
let count = 0;
|
|
97
|
-
let i = window.setInterval(() => {
|
|
98
|
-
count++;
|
|
99
|
-
if (window['monaco'] != undefined) {
|
|
100
|
-
window.clearInterval(i);
|
|
101
|
-
Monaco = window['monaco'];
|
|
102
|
-
res(true);
|
|
103
|
-
}
|
|
104
|
-
if (count >= 100) {
|
|
105
|
-
window.clearInterval(i);
|
|
106
|
-
res(false);
|
|
107
|
-
}
|
|
108
|
-
}, 100);
|
|
109
|
-
});
|
|
95
|
+
await InstallMonacoUMD();
|
|
110
96
|
this.createEditor();
|
|
111
97
|
}
|
|
112
98
|
ngOnDestroy() {
|
|
@@ -130,35 +116,6 @@ export class VscodeComponent {
|
|
|
130
116
|
}
|
|
131
117
|
configureLanguageSupport() {
|
|
132
118
|
}
|
|
133
|
-
installMonaco() {
|
|
134
|
-
if (VscodeComponent.isMonacoInstalled)
|
|
135
|
-
return;
|
|
136
|
-
if (window['monaco']) {
|
|
137
|
-
VscodeComponent.isMonacoInstalled = true;
|
|
138
|
-
return;
|
|
139
|
-
}
|
|
140
|
-
// Monaco has a UMD loader that requires this
|
|
141
|
-
// Merge with any pre-existing global require objects.
|
|
142
|
-
if (!window['require'])
|
|
143
|
-
window['require'] = {};
|
|
144
|
-
if (!window['require']['paths'])
|
|
145
|
-
window['require']['paths'] = {};
|
|
146
|
-
if (this.installationLocation.endsWith('/'))
|
|
147
|
-
this.installationLocation = this.installationLocation.slice(0, -1);
|
|
148
|
-
window['require']['paths'].vs = this.installationLocation;
|
|
149
|
-
const monacoFiles = [
|
|
150
|
-
'loader.js',
|
|
151
|
-
'editor/editor.main.nls.js',
|
|
152
|
-
'editor/editor.main.js',
|
|
153
|
-
];
|
|
154
|
-
for (let i = 0; i < monacoFiles.length; i++) {
|
|
155
|
-
const script = document.createElement("script");
|
|
156
|
-
script.setAttribute("defer", "");
|
|
157
|
-
script.setAttribute("src", this.installationLocation + '/' + monacoFiles[i]);
|
|
158
|
-
document.body.append(script);
|
|
159
|
-
}
|
|
160
|
-
VscodeComponent.isMonacoInstalled = true;
|
|
161
|
-
}
|
|
162
119
|
download() {
|
|
163
120
|
const code = this.editor.getValue();
|
|
164
121
|
let blob = new Blob([code], { type: 'text/log' });
|
|
@@ -174,10 +131,6 @@ export class VscodeComponent {
|
|
|
174
131
|
URL.revokeObjectURL(blobURL);
|
|
175
132
|
}
|
|
176
133
|
}
|
|
177
|
-
/**
|
|
178
|
-
* true if the monaco UMD files are injected into the webpage
|
|
179
|
-
*/
|
|
180
|
-
VscodeComponent.isMonacoInstalled = false;
|
|
181
134
|
VscodeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: VscodeComponent, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
182
135
|
VscodeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: VscodeComponent, isStandalone: true, selector: "app-vscode", inputs: { code: "code", customLanguage: "customLanguage", language: "language", installationLocation: "installationLocation", tabSize: "tabSize", readOnly: "readOnly", theme: "theme", fontFamily: "fontFamily", fontSize: "fontSize", automaticLayout: "automaticLayout", colorDecorators: "colorDecorators", folding: "folding", minimapEnabled: "minimapEnabled", minimap: "minimap", scrollbar: "scrollbar", smoothScrolling: "smoothScrolling", mouseWheelScrollSensitivity: "mouseWheelScrollSensitivity", scrollBeyondLastLine: "scrollBeyondLastLine", scrollBeyondLastColumn: "scrollBeyondLastColumn", lineNumbers: "lineNumbers", restSettings: "restSettings" }, outputs: { codeChange: "codeChange" }, host: { listeners: { "window:resize": "resize($event)" } }, usesOnChanges: true, ngImport: i0, template: '', isInline: true, styles: [":host{display:block;height:100%;max-height:100vh;max-width:100vw}\n"] });
|
|
183
136
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: VscodeComponent, decorators: [{
|
|
@@ -231,4 +184,50 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
231
184
|
type: HostListener,
|
|
232
185
|
args: ['window:resize', ['$event']]
|
|
233
186
|
}] } });
|
|
234
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vscode.component.js","sourceRoot":"","sources":["../../../../../packages/common/src/components/vscode/vscode.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, EventEmitter, HostListener, Input, OnDestroy, Output, SimpleChanges, ViewChild, ViewContainerRef } from '@angular/core';\r\n\r\nimport * as MonacoEditor from 'monaco-editor';\r\nimport { MonacoAutoTypeImporter } from './ts-type-resolver/main';\r\nimport { debounceTime } from 'rxjs';\r\n\r\nlet Monaco: typeof MonacoEditor;\r\n\r\n@Component({\r\n    selector: 'app-vscode',\r\n    template: '',\r\n    styles: [`\r\n:host {\r\n    display: block;\r\n    height: 100%;\r\n    max-height: 100vh;\r\n    max-width: 100vw;\r\n}\r\n    `],\r\n    standalone: true\r\n})\r\nexport class VscodeComponent implements AfterViewInit, OnDestroy {\r\n    isDirty = false;\r\n    editor: MonacoEditor.editor.IStandaloneCodeEditor;\r\n    filename: string;\r\n\r\n    private _code: string;\r\n    @Input() set code(value: string) {\r\n        if (value == this._code)\r\n            return;\r\n        if (typeof value != \"string\")\r\n            throw new TypeError(\"Value must be of type string\");\r\n\r\n        this._code = value;\r\n        this.editor?.setValue(this.code);\r\n    };\r\n    get code() { return this._code?.trim() }\r\n    @Output() codeChange = new EventEmitter<string>();\r\n    private onCodeType = new EventEmitter<string>();\r\n    private typeDebounce = this.onCodeType.pipe(debounceTime(100));\r\n\r\n    @Input() customLanguage: { init: Function; };\r\n\r\n\r\n    private _language: string;\r\n    @Input() set language(value: string) {\r\n        this._language = {\r\n            'ts': \"typescript\",\r\n            'html': 'xml',\r\n            'scss': 'css'\r\n        }[value] || value || \"auto\"\r\n    }\r\n    get language() { return this._language }\r\n\r\n    @Input() installationLocation = \"/lib/monaco/vs\";\r\n\r\n\r\n    @Input() tabSize = 2;\r\n    @Input() readOnly = false;\r\n    @Input() theme = \"vs-dark\";\r\n    @Input() fontFamily = \"Droid Sans Mono\";\r\n    @Input() fontSize = 14;\r\n\r\n    @Input() automaticLayout = true;\r\n    @Input() colorDecorators = true;\r\n    @Input() folding = true;\r\n\r\n    @Input() minimapEnabled = true;\r\n    @Input() minimap: MonacoEditor.editor.IEditorMinimapOptions = {\r\n        enabled: true\r\n    };\r\n    @Input() scrollbar: MonacoEditor.editor.IEditorScrollbarOptions = {\r\n        alwaysConsumeMouseWheel: false,\r\n        // scrollByPage: true\r\n    };\r\n    @Input() smoothScrolling = true;\r\n    @Input() mouseWheelScrollSensitivity = 2;\r\n    @Input() scrollBeyondLastLine = false;\r\n    @Input() scrollBeyondLastColumn = 0;\r\n\r\n    @Input() lineNumbers: MonacoEditor.editor.LineNumbersType = \"on\";\r\n\r\n    @Input() restSettings: MonacoEditor.editor.IStandaloneEditorConstructionOptions = {};\r\n\r\n    get settings() {\r\n        return {\r\n            ...this.restSettings,\r\n            theme: this.theme,\r\n            language: this.language,\r\n            tabSize: this.tabSize,\r\n            readOnly: this.readOnly,\r\n            fontFamily: this.fontFamily,\r\n            fontSize: this.fontSize,\r\n            automaticLayout: this.automaticLayout,\r\n            scrollBeyondLastLine: this.scrollBeyondLastLine,\r\n            colorDecorators: this.colorDecorators,\r\n            folding: this.folding,\r\n            scrollBeyondLastColumn: this.scrollBeyondLastColumn,\r\n            minimap: this.minimap,\r\n            scrollbar: this.scrollbar,\r\n            smoothScrolling: this.smoothScrolling,\r\n            mouseWheelScrollSensitivity: this.mouseWheelScrollSensitivity,\r\n            lineNumbers: this.lineNumbers\r\n        } as MonacoEditor.editor.IStandaloneEditorConstructionOptions;\r\n    }\r\n\r\n    private _sub;\r\n    constructor(private viewContainer: ViewContainerRef) {\r\n        this.installMonaco();\r\n\r\n        this._sub = this.typeDebounce.subscribe(t => {\r\n            this.codeChange.next(this._code = this.editor.getValue());\r\n        });\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        // If we changed anything OTHER than code, reload the editor\r\n        if (Object.keys(changes).length > 1 || !changes['code']) {\r\n            if (this.editor) {\r\n                this.editor?.dispose();\r\n                this.createEditor();\r\n            }\r\n        }\r\n        if (changes['theme'])\r\n            Monaco?.editor.setTheme(this.theme);\r\n    }\r\n\r\n    async ngAfterViewInit() {\r\n\r\n        await new Promise((res, rej) => {\r\n            let count = 0;\r\n            let i = window.setInterval(() => {\r\n                count++;\r\n\r\n                if (window['monaco'] != undefined) {\r\n                    window.clearInterval(i);\r\n\r\n                    Monaco = window['monaco'];\r\n                    res(true);\r\n                }\r\n                if (count >= 100) {\r\n                    window.clearInterval(i);\r\n                    res(false);\r\n                }\r\n            }, 100);\r\n        });\r\n\r\n        this.createEditor();\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this.editor?.dispose();\r\n        this._sub?.unsubscribe();\r\n    }\r\n\r\n    private createEditor() {\r\n        if (this.customLanguage) {\r\n            this.customLanguage.init(Monaco);\r\n        }\r\n\r\n\r\n        let editor = this.editor = Monaco.editor.create(this.viewContainer?.element?.nativeElement, this.settings as any);\r\n\r\n        // const autoTypings = await\r\n        MonacoAutoTypeImporter.create(editor, {\r\n            monaco: Monaco,\r\n        });\r\n\r\n        this.configureLanguageSupport();\r\n\r\n        if (this.code) {\r\n            editor.setValue(this.code);\r\n        }\r\n\r\n        editor.getModel().onDidChangeContent(() => this.onCodeType.emit());\r\n    }\r\n\r\n    private configureLanguageSupport() {\r\n\r\n    }\r\n\r\n    /**\r\n     * true if the monaco UMD files are injected into the webpage\r\n     */\r\n    private static isMonacoInstalled = false;\r\n    private installMonaco() {\r\n        if (VscodeComponent.isMonacoInstalled) return;\r\n\r\n        if (window['monaco']) {\r\n            VscodeComponent.isMonacoInstalled = true;\r\n            return;\r\n        }\r\n\r\n        // Monaco has a UMD loader that requires this\r\n        // Merge with any pre-existing global require objects.\r\n        if (!window['require']) window['require'] = {} as any;\r\n        if (!window['require']['paths']) window['require']['paths'] = {};\r\n\r\n        if (this.installationLocation.endsWith('/'))\r\n            this.installationLocation = this.installationLocation.slice(0, -1);\r\n\r\n        window['require']['paths'].vs = this.installationLocation;\r\n\r\n        const monacoFiles = [\r\n            'loader.js',\r\n            'editor/editor.main.nls.js',\r\n            'editor/editor.main.js',\r\n        ];\r\n\r\n        for (let i = 0; i < monacoFiles.length; i++) {\r\n            const script = document.createElement(\"script\");\r\n            script.setAttribute(\"defer\", \"\");\r\n            script.setAttribute(\"src\", this.installationLocation + '/' + monacoFiles[i]);\r\n            document.body.append(script);\r\n        }\r\n        VscodeComponent.isMonacoInstalled = true;\r\n    }\r\n\r\n    download() {\r\n        const code = this.editor.getValue();\r\n\r\n        let blob = new Blob([code], { type: 'text/log' });\r\n        let elm = document.createElement('a');\r\n        let blobURL = URL.createObjectURL(blob);\r\n\r\n        // Set the data values.\r\n        elm.href = blobURL;\r\n        elm.download = this.filename;\r\n\r\n        document.body.appendChild(elm);\r\n        elm.click();\r\n\r\n        document.body.removeChild(elm);\r\n        elm.remove();\r\n\r\n        URL.revokeObjectURL(blobURL);\r\n    }\r\n\r\n    @HostListener('window:resize', ['$event'])\r\n    resize = (): void => {\r\n        this.editor?.layout();\r\n    };\r\n}\r\n"]}
|
|
187
|
+
export const InstallMonacoUMD = async (path) => {
|
|
188
|
+
if (window['monaco'])
|
|
189
|
+
return window['monaco'];
|
|
190
|
+
// Prevent duplicate injection
|
|
191
|
+
const scriptEls = document.querySelectorAll('body>script[monaco][defer][src]');
|
|
192
|
+
// Only perform installation if a path is specified.
|
|
193
|
+
if (path && scriptEls.length == 0) {
|
|
194
|
+
// Monaco has a UMD loader that requires this
|
|
195
|
+
// Merge with any pre-existing global require objects.
|
|
196
|
+
if (!window['require'])
|
|
197
|
+
window['require'] = {};
|
|
198
|
+
if (!window['require']['paths'])
|
|
199
|
+
window['require']['paths'] = {};
|
|
200
|
+
if (path.endsWith('/'))
|
|
201
|
+
path = path.slice(0, -1);
|
|
202
|
+
window['require']['paths'].vs = path;
|
|
203
|
+
const monacoFiles = [
|
|
204
|
+
'loader.js',
|
|
205
|
+
'editor/editor.main.nls.js',
|
|
206
|
+
'editor/editor.main.js',
|
|
207
|
+
];
|
|
208
|
+
for (let i = 0; i < monacoFiles.length; i++) {
|
|
209
|
+
const script = document.createElement("script");
|
|
210
|
+
script.setAttribute("monaco", "");
|
|
211
|
+
script.setAttribute("defer", "");
|
|
212
|
+
script.setAttribute("src", path + '/' + monacoFiles[i]);
|
|
213
|
+
document.body.append(script);
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
// Return a promise that will resolve when monaco finishes loading
|
|
217
|
+
return await new Promise((res, rej) => {
|
|
218
|
+
let count = 0;
|
|
219
|
+
let i = window.setInterval(() => {
|
|
220
|
+
count++;
|
|
221
|
+
if (window['monaco'] != undefined) {
|
|
222
|
+
window.clearInterval(i);
|
|
223
|
+
Monaco = window['monaco'];
|
|
224
|
+
res(true);
|
|
225
|
+
}
|
|
226
|
+
else if (count >= 100) {
|
|
227
|
+
window.clearInterval(i);
|
|
228
|
+
res(false);
|
|
229
|
+
}
|
|
230
|
+
}, 100);
|
|
231
|
+
});
|
|
232
|
+
};
|
|
233
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vscode.component.js","sourceRoot":"","sources":["../../../../../packages/common/src/components/vscode/vscode.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAE,YAAY,EAAE,YAAY,EAAE,KAAK,EAAa,MAAM,EAA8C,MAAM,eAAe,CAAC;AAG3J,OAAO,EAAE,sBAAsB,EAAE,MAAM,yBAAyB,CAAC;AACjE,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAC;;AAEpC,IAAI,MAA2B,CAAC;AAehC,MAAM,OAAO,eAAe;IAMxB,IAAa,IAAI,CAAC,KAAa;QAC3B,IAAI,KAAK,IAAI,IAAI,CAAC,KAAK;YACnB,OAAO;QACX,IAAI,OAAO,KAAK,IAAI,QAAQ;YACxB,MAAM,IAAI,SAAS,CAAC,8BAA8B,CAAC,CAAC;QAExD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,MAAM,EAAE,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACrC,CAAC;IAAA,CAAC;IACF,IAAI,IAAI,KAAK,OAAO,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,CAAA,CAAC,CAAC;IASxC,IAAa,QAAQ,CAAC,KAAa;QAC/B,IAAI,CAAC,SAAS,GAAG;YACb,IAAI,EAAE,YAAY;YAClB,MAAM,EAAE,KAAK;YACb,MAAM,EAAE,KAAK;SAChB,CAAC,KAAK,CAAC,IAAI,KAAK,IAAI,MAAM,CAAA;IAC/B,CAAC;IACD,IAAI,QAAQ,KAAK,OAAO,IAAI,CAAC,SAAS,CAAA,CAAC,CAAC;IAgCxC,IAAI,QAAQ;QACR,OAAO;YACH,GAAG,IAAI,CAAC,YAAY;YACpB,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,eAAe,EAAE,IAAI,CAAC,eAAe;YACrC,oBAAoB,EAAE,IAAI,CAAC,oBAAoB;YAC/C,eAAe,EAAE,IAAI,CAAC,eAAe;YACrC,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,sBAAsB,EAAE,IAAI,CAAC,sBAAsB;YACnD,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,eAAe,EAAE,IAAI,CAAC,eAAe;YACrC,2BAA2B,EAAE,IAAI,CAAC,2BAA2B;YAC7D,WAAW,EAAE,IAAI,CAAC,WAAW;SAC4B,CAAC;IAClE,CAAC;IAGD,YAAoB,aAA+B;QAA/B,kBAAa,GAAb,aAAa,CAAkB;QArFnD,YAAO,GAAG,KAAK,CAAC;QAeN,eAAU,GAAG,IAAI,YAAY,EAAU,CAAC;QAC1C,eAAU,GAAG,IAAI,YAAY,EAAU,CAAC;QACxC,iBAAY,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC;QAetD,yBAAoB,GAAG,gBAAgB,CAAC;QAGxC,YAAO,GAAG,CAAC,CAAC;QACZ,aAAQ,GAAG,KAAK,CAAC;QACjB,UAAK,GAAG,SAAS,CAAC;QAClB,eAAU,GAAG,iBAAiB,CAAC;QAC/B,aAAQ,GAAG,EAAE,CAAC;QAEd,oBAAe,GAAG,IAAI,CAAC;QACvB,oBAAe,GAAG,IAAI,CAAC;QACvB,YAAO,GAAG,IAAI,CAAC;QAEf,mBAAc,GAAG,IAAI,CAAC;QACtB,YAAO,GAA8C;YAC1D,OAAO,EAAE,IAAI;SAChB,CAAC;QACO,cAAS,GAAgD;YAC9D,uBAAuB,EAAE,KAAK;YAC9B,qBAAqB;SACxB,CAAC;QACO,oBAAe,GAAG,IAAI,CAAC;QACvB,gCAA2B,GAAG,CAAC,CAAC;QAChC,yBAAoB,GAAG,KAAK,CAAC;QAC7B,2BAAsB,GAAG,CAAC,CAAC;QAE3B,gBAAW,GAAwC,IAAI,CAAC;QAExD,iBAAY,GAA6D,EAAE,CAAC;QAyGrF,WAAM,GAAG,GAAS,EAAE;YAChB,IAAI,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC;QAC1B,CAAC,CAAC;QAjFE,gBAAgB,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;QAE5C,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YACxC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC9D,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW,CAAC,OAAsB;QAC9B,4DAA4D;QAC5D,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACrD,IAAI,IAAI,CAAC,MAAM,EAAE;gBACb,IAAI,CAAC,MAAM,EAAE,OAAO,EAAE,CAAC;gBACvB,IAAI,CAAC,YAAY,EAAE,CAAC;aACvB;SACJ;QACD,IAAI,OAAO,CAAC,OAAO,CAAC;YAChB,MAAM,EAAE,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC5C,CAAC;IAED,KAAK,CAAC,eAAe;QACjB,MAAM,gBAAgB,EAAE,CAAC;QAEzB,IAAI,CAAC,YAAY,EAAE,CAAC;IACxB,CAAC;IAED,WAAW;QACP,IAAI,CAAC,MAAM,EAAE,OAAO,EAAE,CAAC;QACvB,IAAI,CAAC,IAAI,EAAE,WAAW,EAAE,CAAC;IAC7B,CAAC;IAEO,YAAY;QAChB,IAAI,IAAI,CAAC,cAAc,EAAE;YACrB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SACpC;QAED,IAAI,MAAM,GAAG,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAC3C,IAAI,CAAC,aAAa,EAAE,OAAO,EAAE,aAAa,EAC1C,IAAI,CAAC,QAAe,CACvB,CAAC;QAEF,4BAA4B;QAC5B,sBAAsB,CAAC,MAAM,CAAC,MAAM,EAAE;YAClC,MAAM,EAAE,MAAM;SACjB,CAAC,CAAC;QAEH,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAEhC,IAAI,IAAI,CAAC,IAAI,EAAE;YACX,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAC9B;QAED,MAAM,CAAC,QAAQ,EAAE,CAAC,kBAAkB,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC,CAAC;IACvE,CAAC;IAEO,wBAAwB;IAEhC,CAAC;IAED,QAAQ;QACJ,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;QAEpC,IAAI,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;QAClD,IAAI,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;QACtC,IAAI,OAAO,GAAG,GAAG,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QAExC,uBAAuB;QACvB,GAAG,CAAC,IAAI,GAAG,OAAO,CAAC;QACnB,GAAG,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAE7B,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QAC/B,GAAG,CAAC,KAAK,EAAE,CAAC;QAEZ,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QAC/B,GAAG,CAAC,MAAM,EAAE,CAAC;QAEb,GAAG,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;IACjC,CAAC;;4GAnKQ,eAAe;gGAAf,eAAe,40BAXd,EAAE;2FAWH,eAAe;kBAb3B,SAAS;+BACI,YAAY,YACZ,EAAE,cASA,IAAI;uGAQH,IAAI;sBAAhB,KAAK;gBAUI,UAAU;sBAAnB,MAAM;gBAIE,cAAc;sBAAtB,KAAK;gBAIO,QAAQ;sBAApB,KAAK;gBASG,oBAAoB;sBAA5B,KAAK;gBAGG,OAAO;sBAAf,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBAEG,eAAe;sBAAvB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBAEG,cAAc;sBAAtB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBAGG,SAAS;sBAAjB,KAAK;gBAIG,eAAe;sBAAvB,KAAK;gBACG,2BAA2B;sBAAnC,KAAK;gBACG,oBAAoB;sBAA5B,KAAK;gBACG,sBAAsB;sBAA9B,KAAK;gBAEG,WAAW;sBAAnB,KAAK;gBAEG,YAAY;sBAApB,KAAK;gBAyGN,MAAM;sBADL,YAAY;uBAAC,eAAe,EAAE,CAAC,QAAQ,CAAC;;AAM7C,MAAM,CAAC,MAAM,gBAAgB,GAAG,KAAK,EAAE,IAAa,EAAE,EAAE;IACpD,IAAI,MAAM,CAAC,QAAQ,CAAC;QAAE,OAAO,MAAM,CAAC,QAAQ,CAAC,CAAC;IAE9C,8BAA8B;IAC9B,MAAM,SAAS,GAAG,QAAQ,CAAC,gBAAgB,CAAC,iCAAiC,CAAC,CAAC;IAE/E,oDAAoD;IACpD,IAAI,IAAI,IAAI,SAAS,CAAC,MAAM,IAAI,CAAC,EAAE;QAC/B,6CAA6C;QAC7C,sDAAsD;QACtD,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC;YAAE,MAAM,CAAC,SAAS,CAAC,GAAG,EAAS,CAAC;QACtD,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC;YAAE,MAAM,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC;QAEjE,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC;YAClB,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAE7B,MAAM,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE,GAAG,IAAI,CAAC;QAErC,MAAM,WAAW,GAAG;YAChB,WAAW;YACX,2BAA2B;YAC3B,uBAAuB;SAC1B,CAAC;QAEF,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACzC,MAAM,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;YAChD,MAAM,CAAC,YAAY,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;YAClC,MAAM,CAAC,YAAY,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;YACjC,MAAM,CAAC,YAAY,CAAC,KAAK,EAAE,IAAI,GAAG,GAAG,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;YACxD,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;SAChC;KACJ;IAED,kEAAkE;IAClE,OAAO,MAAM,IAAI,OAAO,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;QAClC,IAAI,KAAK,GAAG,CAAC,CAAC;QACd,IAAI,CAAC,GAAG,MAAM,CAAC,WAAW,CAAC,GAAG,EAAE;YAC5B,KAAK,EAAE,CAAC;YAER,IAAI,MAAM,CAAC,QAAQ,CAAC,IAAI,SAAS,EAAE;gBAC/B,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;gBAExB,MAAM,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;gBAC1B,GAAG,CAAC,IAAI,CAAC,CAAC;aACb;iBACI,IAAI,KAAK,IAAI,GAAG,EAAE;gBACnB,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;gBACxB,GAAG,CAAC,KAAK,CAAC,CAAC;aACd;QACL,CAAC,EAAE,GAAG,CAAC,CAAC;IACZ,CAAC,CAAC,CAAC;AACP,CAAC,CAAA","sourcesContent":["import { AfterViewInit, Component, EventEmitter, HostListener, Input, OnDestroy, Output, SimpleChanges, ViewChild, ViewContainerRef } from '@angular/core';\r\n\r\nimport * as MonacoEditor from 'monaco-editor';\r\nimport { MonacoAutoTypeImporter } from './ts-type-resolver/main';\r\nimport { debounceTime } from 'rxjs';\r\n\r\nlet Monaco: typeof MonacoEditor;\r\n\r\n@Component({\r\n    selector: 'app-vscode',\r\n    template: '',\r\n    styles: [`\r\n:host {\r\n    display: block;\r\n    height: 100%;\r\n    max-height: 100vh;\r\n    max-width: 100vw;\r\n}\r\n    `],\r\n    standalone: true\r\n})\r\nexport class VscodeComponent implements AfterViewInit, OnDestroy {\r\n    isDirty = false;\r\n    editor: MonacoEditor.editor.IStandaloneCodeEditor;\r\n    filename: string;\r\n\r\n    private _code: string;\r\n    @Input() set code(value: string) {\r\n        if (value == this._code)\r\n            return;\r\n        if (typeof value != \"string\")\r\n            throw new TypeError(\"Value must be of type string\");\r\n\r\n        this._code = value;\r\n        this.editor?.setValue(this.code);\r\n    };\r\n    get code() { return this._code?.trim() }\r\n    @Output() codeChange = new EventEmitter<string>();\r\n    private onCodeType = new EventEmitter<string>();\r\n    private typeDebounce = this.onCodeType.pipe(debounceTime(100));\r\n\r\n    @Input() customLanguage: { init: Function; };\r\n\r\n\r\n    private _language: string;\r\n    @Input() set language(value: string) {\r\n        this._language = {\r\n            'ts': \"typescript\",\r\n            'html': 'xml',\r\n            'scss': 'css'\r\n        }[value] || value || \"auto\"\r\n    }\r\n    get language() { return this._language }\r\n\r\n    @Input() installationLocation = \"/lib/monaco/vs\";\r\n\r\n\r\n    @Input() tabSize = 2;\r\n    @Input() readOnly = false;\r\n    @Input() theme = \"vs-dark\";\r\n    @Input() fontFamily = \"Droid Sans Mono\";\r\n    @Input() fontSize = 14;\r\n\r\n    @Input() automaticLayout = true;\r\n    @Input() colorDecorators = true;\r\n    @Input() folding = true;\r\n\r\n    @Input() minimapEnabled = true;\r\n    @Input() minimap: MonacoEditor.editor.IEditorMinimapOptions = {\r\n        enabled: true\r\n    };\r\n    @Input() scrollbar: MonacoEditor.editor.IEditorScrollbarOptions = {\r\n        alwaysConsumeMouseWheel: false,\r\n        // scrollByPage: true\r\n    };\r\n    @Input() smoothScrolling = true;\r\n    @Input() mouseWheelScrollSensitivity = 2;\r\n    @Input() scrollBeyondLastLine = false;\r\n    @Input() scrollBeyondLastColumn = 0;\r\n\r\n    @Input() lineNumbers: MonacoEditor.editor.LineNumbersType = \"on\";\r\n\r\n    @Input() restSettings: MonacoEditor.editor.IStandaloneEditorConstructionOptions = {};\r\n\r\n    get settings() {\r\n        return {\r\n            ...this.restSettings,\r\n            theme: this.theme,\r\n            language: this.language,\r\n            tabSize: this.tabSize,\r\n            readOnly: this.readOnly,\r\n            fontFamily: this.fontFamily,\r\n            fontSize: this.fontSize,\r\n            automaticLayout: this.automaticLayout,\r\n            scrollBeyondLastLine: this.scrollBeyondLastLine,\r\n            colorDecorators: this.colorDecorators,\r\n            folding: this.folding,\r\n            scrollBeyondLastColumn: this.scrollBeyondLastColumn,\r\n            minimap: this.minimap,\r\n            scrollbar: this.scrollbar,\r\n            smoothScrolling: this.smoothScrolling,\r\n            mouseWheelScrollSensitivity: this.mouseWheelScrollSensitivity,\r\n            lineNumbers: this.lineNumbers\r\n        } as MonacoEditor.editor.IStandaloneEditorConstructionOptions;\r\n    }\r\n\r\n    private _sub;\r\n    constructor(private viewContainer: ViewContainerRef) {\r\n        InstallMonacoUMD(this.installationLocation);\r\n\r\n        this._sub = this.typeDebounce.subscribe(t => {\r\n            this.codeChange.next(this._code = this.editor.getValue());\r\n        });\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        // If we changed anything OTHER than code, reload the editor\r\n        if (Object.keys(changes).length > 1 || !changes['code']) {\r\n            if (this.editor) {\r\n                this.editor?.dispose();\r\n                this.createEditor();\r\n            }\r\n        }\r\n        if (changes['theme'])\r\n            Monaco?.editor.setTheme(this.theme);\r\n    }\r\n\r\n    async ngAfterViewInit() {\r\n        await InstallMonacoUMD();\r\n\r\n        this.createEditor();\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this.editor?.dispose();\r\n        this._sub?.unsubscribe();\r\n    }\r\n\r\n    private createEditor() {\r\n        if (this.customLanguage) {\r\n            this.customLanguage.init(Monaco);\r\n        }\r\n\r\n        let editor = this.editor = Monaco.editor.create(\r\n            this.viewContainer?.element?.nativeElement,\r\n            this.settings as any\r\n        );\r\n\r\n        // const autoTypings = await\r\n        MonacoAutoTypeImporter.create(editor, {\r\n            monaco: Monaco,\r\n        });\r\n\r\n        this.configureLanguageSupport();\r\n\r\n        if (this.code) {\r\n            editor.setValue(this.code);\r\n        }\r\n\r\n        editor.getModel().onDidChangeContent(() => this.onCodeType.emit());\r\n    }\r\n\r\n    private configureLanguageSupport() {\r\n\r\n    }\r\n\r\n    download() {\r\n        const code = this.editor.getValue();\r\n\r\n        let blob = new Blob([code], { type: 'text/log' });\r\n        let elm = document.createElement('a');\r\n        let blobURL = URL.createObjectURL(blob);\r\n\r\n        // Set the data values.\r\n        elm.href = blobURL;\r\n        elm.download = this.filename;\r\n\r\n        document.body.appendChild(elm);\r\n        elm.click();\r\n\r\n        document.body.removeChild(elm);\r\n        elm.remove();\r\n\r\n        URL.revokeObjectURL(blobURL);\r\n    }\r\n\r\n    @HostListener('window:resize', ['$event'])\r\n    resize = (): void => {\r\n        this.editor?.layout();\r\n    };\r\n}\r\n\r\nexport const InstallMonacoUMD = async (path?: string) => {\r\n    if (window['monaco']) return window['monaco'];\r\n\r\n    // Prevent duplicate injection\r\n    const scriptEls = document.querySelectorAll('body>script[monaco][defer][src]');\r\n\r\n    // Only perform installation if a path is specified.\r\n    if (path && scriptEls.length == 0) {\r\n        // Monaco has a UMD loader that requires this\r\n        // Merge with any pre-existing global require objects.\r\n        if (!window['require']) window['require'] = {} as any;\r\n        if (!window['require']['paths']) window['require']['paths'] = {};\r\n\r\n        if (path.endsWith('/'))\r\n            path = path.slice(0, -1);\r\n\r\n        window['require']['paths'].vs = path;\r\n\r\n        const monacoFiles = [\r\n            'loader.js',\r\n            'editor/editor.main.nls.js',\r\n            'editor/editor.main.js',\r\n        ];\r\n\r\n        for (let i = 0; i < monacoFiles.length; i++) {\r\n            const script = document.createElement(\"script\");\r\n            script.setAttribute(\"monaco\", \"\");\r\n            script.setAttribute(\"defer\", \"\");\r\n            script.setAttribute(\"src\", path + '/' + monacoFiles[i]);\r\n            document.body.append(script);\r\n        }\r\n    }\r\n\r\n    // Return a promise that will resolve when monaco finishes loading\r\n    return await new Promise((res, rej) => {\r\n        let count = 0;\r\n        let i = window.setInterval(() => {\r\n            count++;\r\n\r\n            if (window['monaco'] != undefined) {\r\n                window.clearInterval(i);\r\n\r\n                Monaco = window['monaco'];\r\n                res(true);\r\n            }\r\n            else if (count >= 100) {\r\n                window.clearInterval(i);\r\n                res(false);\r\n            }\r\n        }, 100);\r\n    });\r\n}\r\n"]}
|
|
@@ -10397,7 +10397,7 @@ class VscodeComponent {
|
|
|
10397
10397
|
var _a;
|
|
10398
10398
|
(_a = this.editor) === null || _a === void 0 ? void 0 : _a.layout();
|
|
10399
10399
|
};
|
|
10400
|
-
this.
|
|
10400
|
+
InstallMonacoUMD(this.installationLocation);
|
|
10401
10401
|
this._sub = this.typeDebounce.subscribe(t => {
|
|
10402
10402
|
this.codeChange.next(this._code = this.editor.getValue());
|
|
10403
10403
|
});
|
|
@@ -10416,21 +10416,7 @@ class VscodeComponent {
|
|
|
10416
10416
|
}
|
|
10417
10417
|
ngAfterViewInit() {
|
|
10418
10418
|
return __awaiter(this, void 0, void 0, function* () {
|
|
10419
|
-
yield
|
|
10420
|
-
let count = 0;
|
|
10421
|
-
let i = window.setInterval(() => {
|
|
10422
|
-
count++;
|
|
10423
|
-
if (window['monaco'] != undefined) {
|
|
10424
|
-
window.clearInterval(i);
|
|
10425
|
-
Monaco = window['monaco'];
|
|
10426
|
-
res(true);
|
|
10427
|
-
}
|
|
10428
|
-
if (count >= 100) {
|
|
10429
|
-
window.clearInterval(i);
|
|
10430
|
-
res(false);
|
|
10431
|
-
}
|
|
10432
|
-
}, 100);
|
|
10433
|
-
});
|
|
10419
|
+
yield InstallMonacoUMD();
|
|
10434
10420
|
this.createEditor();
|
|
10435
10421
|
});
|
|
10436
10422
|
}
|
|
@@ -10457,35 +10443,6 @@ class VscodeComponent {
|
|
|
10457
10443
|
}
|
|
10458
10444
|
configureLanguageSupport() {
|
|
10459
10445
|
}
|
|
10460
|
-
installMonaco() {
|
|
10461
|
-
if (VscodeComponent.isMonacoInstalled)
|
|
10462
|
-
return;
|
|
10463
|
-
if (window['monaco']) {
|
|
10464
|
-
VscodeComponent.isMonacoInstalled = true;
|
|
10465
|
-
return;
|
|
10466
|
-
}
|
|
10467
|
-
// Monaco has a UMD loader that requires this
|
|
10468
|
-
// Merge with any pre-existing global require objects.
|
|
10469
|
-
if (!window['require'])
|
|
10470
|
-
window['require'] = {};
|
|
10471
|
-
if (!window['require']['paths'])
|
|
10472
|
-
window['require']['paths'] = {};
|
|
10473
|
-
if (this.installationLocation.endsWith('/'))
|
|
10474
|
-
this.installationLocation = this.installationLocation.slice(0, -1);
|
|
10475
|
-
window['require']['paths'].vs = this.installationLocation;
|
|
10476
|
-
const monacoFiles = [
|
|
10477
|
-
'loader.js',
|
|
10478
|
-
'editor/editor.main.nls.js',
|
|
10479
|
-
'editor/editor.main.js',
|
|
10480
|
-
];
|
|
10481
|
-
for (let i = 0; i < monacoFiles.length; i++) {
|
|
10482
|
-
const script = document.createElement("script");
|
|
10483
|
-
script.setAttribute("defer", "");
|
|
10484
|
-
script.setAttribute("src", this.installationLocation + '/' + monacoFiles[i]);
|
|
10485
|
-
document.body.append(script);
|
|
10486
|
-
}
|
|
10487
|
-
VscodeComponent.isMonacoInstalled = true;
|
|
10488
|
-
}
|
|
10489
10446
|
download() {
|
|
10490
10447
|
const code = this.editor.getValue();
|
|
10491
10448
|
let blob = new Blob([code], { type: 'text/log' });
|
|
@@ -10501,10 +10458,6 @@ class VscodeComponent {
|
|
|
10501
10458
|
URL.revokeObjectURL(blobURL);
|
|
10502
10459
|
}
|
|
10503
10460
|
}
|
|
10504
|
-
/**
|
|
10505
|
-
* true if the monaco UMD files are injected into the webpage
|
|
10506
|
-
*/
|
|
10507
|
-
VscodeComponent.isMonacoInstalled = false;
|
|
10508
10461
|
VscodeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: VscodeComponent, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
10509
10462
|
VscodeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: VscodeComponent, isStandalone: true, selector: "app-vscode", inputs: { code: "code", customLanguage: "customLanguage", language: "language", installationLocation: "installationLocation", tabSize: "tabSize", readOnly: "readOnly", theme: "theme", fontFamily: "fontFamily", fontSize: "fontSize", automaticLayout: "automaticLayout", colorDecorators: "colorDecorators", folding: "folding", minimapEnabled: "minimapEnabled", minimap: "minimap", scrollbar: "scrollbar", smoothScrolling: "smoothScrolling", mouseWheelScrollSensitivity: "mouseWheelScrollSensitivity", scrollBeyondLastLine: "scrollBeyondLastLine", scrollBeyondLastColumn: "scrollBeyondLastColumn", lineNumbers: "lineNumbers", restSettings: "restSettings" }, outputs: { codeChange: "codeChange" }, host: { listeners: { "window:resize": "resize($event)" } }, usesOnChanges: true, ngImport: i0, template: '', isInline: true, styles: [":host{display:block;height:100%;max-height:100vh;max-width:100vw}\n"] });
|
|
10510
10463
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: VscodeComponent, decorators: [{
|
|
@@ -10558,6 +10511,52 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
10558
10511
|
type: HostListener,
|
|
10559
10512
|
args: ['window:resize', ['$event']]
|
|
10560
10513
|
}] } });
|
|
10514
|
+
const InstallMonacoUMD = (path) => __awaiter(void 0, void 0, void 0, function* () {
|
|
10515
|
+
if (window['monaco'])
|
|
10516
|
+
return window['monaco'];
|
|
10517
|
+
// Prevent duplicate injection
|
|
10518
|
+
const scriptEls = document.querySelectorAll('body>script[monaco][defer][src]');
|
|
10519
|
+
// Only perform installation if a path is specified.
|
|
10520
|
+
if (path && scriptEls.length == 0) {
|
|
10521
|
+
// Monaco has a UMD loader that requires this
|
|
10522
|
+
// Merge with any pre-existing global require objects.
|
|
10523
|
+
if (!window['require'])
|
|
10524
|
+
window['require'] = {};
|
|
10525
|
+
if (!window['require']['paths'])
|
|
10526
|
+
window['require']['paths'] = {};
|
|
10527
|
+
if (path.endsWith('/'))
|
|
10528
|
+
path = path.slice(0, -1);
|
|
10529
|
+
window['require']['paths'].vs = path;
|
|
10530
|
+
const monacoFiles = [
|
|
10531
|
+
'loader.js',
|
|
10532
|
+
'editor/editor.main.nls.js',
|
|
10533
|
+
'editor/editor.main.js',
|
|
10534
|
+
];
|
|
10535
|
+
for (let i = 0; i < monacoFiles.length; i++) {
|
|
10536
|
+
const script = document.createElement("script");
|
|
10537
|
+
script.setAttribute("monaco", "");
|
|
10538
|
+
script.setAttribute("defer", "");
|
|
10539
|
+
script.setAttribute("src", path + '/' + monacoFiles[i]);
|
|
10540
|
+
document.body.append(script);
|
|
10541
|
+
}
|
|
10542
|
+
}
|
|
10543
|
+
// Return a promise that will resolve when monaco finishes loading
|
|
10544
|
+
return yield new Promise((res, rej) => {
|
|
10545
|
+
let count = 0;
|
|
10546
|
+
let i = window.setInterval(() => {
|
|
10547
|
+
count++;
|
|
10548
|
+
if (window['monaco'] != undefined) {
|
|
10549
|
+
window.clearInterval(i);
|
|
10550
|
+
Monaco = window['monaco'];
|
|
10551
|
+
res(true);
|
|
10552
|
+
}
|
|
10553
|
+
else if (count >= 100) {
|
|
10554
|
+
window.clearInterval(i);
|
|
10555
|
+
res(false);
|
|
10556
|
+
}
|
|
10557
|
+
}, 100);
|
|
10558
|
+
});
|
|
10559
|
+
});
|
|
10561
10560
|
|
|
10562
10561
|
/**
|
|
10563
10562
|
* Extend this component to automatically generate
|
|
@@ -10638,5 +10637,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
10638
10637
|
* Generated bundle index. Do not edit.
|
|
10639
10638
|
*/
|
|
10640
10639
|
|
|
10641
|
-
export { ComponentResolveStrategy, DependencyService, DialogService, DynamicHTMLComponent, DynamicHTMLOptions, DynamicHTMLRenderer, Fetch, FileService, FilemanagerComponent, HtmlBypass, KeyboardService, LazyLoaderComponent, LazyLoaderModule, LazyLoaderService, MenuDirective, NGX_DYNAMIC_CONFIG, NGX_LAZY_LOADER_CONFIG, NGX_WEB_COMPONENTS_CONFIG, NavigationService, NgxDynamicHTMLModule, OnMount, ReactMagicWrapperComponent, ResourceBypass, ScriptBypass, StyleBypass, TabulatorComponent, ThemeService, TooltipDirective, UrlBypass, VscodeComponent, openMenu, openTooltip };
|
|
10640
|
+
export { ComponentResolveStrategy, DependencyService, DialogService, DynamicHTMLComponent, DynamicHTMLOptions, DynamicHTMLRenderer, Fetch, FileService, FilemanagerComponent, HtmlBypass, InstallMonacoUMD, KeyboardService, LazyLoaderComponent, LazyLoaderModule, LazyLoaderService, MenuDirective, NGX_DYNAMIC_CONFIG, NGX_LAZY_LOADER_CONFIG, NGX_WEB_COMPONENTS_CONFIG, NavigationService, NgxDynamicHTMLModule, OnMount, ReactMagicWrapperComponent, ResourceBypass, ScriptBypass, StyleBypass, TabulatorComponent, ThemeService, TooltipDirective, UrlBypass, VscodeComponent, openMenu, openTooltip };
|
|
10642
10641
|
//# sourceMappingURL=dotglitch-ngx-common.mjs.map
|