@dotglitch/ngx-common 1.2.0 → 3.0.0-beta.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/README.md +37 -22
- package/esm2022/components/lazy-loader/lazy-loader.component.mjs +4 -4
- package/esm2022/components/lazy-loader/lazy-loader.module.mjs +5 -5
- package/esm2022/components/lazy-loader/lazy-loader.service.mjs +4 -4
- package/esm2022/components/menu/menu.component.mjs +4 -4
- package/esm2022/components/parallax-card/parallax-card.component.mjs +4 -4
- package/esm2022/components/tooltip/tooltip.component.mjs +4 -4
- package/esm2022/directives/image-cache.directive.mjs +7 -4
- package/esm2022/directives/menu.directive.mjs +4 -4
- package/esm2022/directives/tooltip.directive.mjs +7 -7
- package/esm2022/pipes/html-bypass.pipe.mjs +4 -4
- package/esm2022/pipes/resource-bypass.pipe.mjs +4 -4
- package/esm2022/pipes/script-bypass.pipe.mjs +4 -4
- package/esm2022/pipes/style-bypass.pipe.mjs +4 -4
- package/esm2022/pipes/url-bypass.pipe.mjs +4 -4
- package/esm2022/public-api.mjs +7 -23
- package/esm2022/services/dependency.service.mjs +4 -4
- package/esm2022/services/dialog.service.mjs +4 -4
- package/esm2022/services/fetch.service.mjs +4 -4
- package/esm2022/services/file.service.mjs +4 -4
- package/esm2022/services/keyboard.service.mjs +4 -4
- package/esm2022/services/navigation.service.mjs +4 -4
- package/esm2022/services/theme.service.mjs +50 -15
- package/fesm2022/dotglitch-ngx-common.mjs +1105 -10155
- package/fesm2022/dotglitch-ngx-common.mjs.map +1 -1
- package/package.json +27 -10
- package/public-api.d.ts +6 -19
- package/services/theme.service.d.ts +12 -2
- package/assets/mat-icons.d.ts +0 -5705
- package/components/command-palette/breadcrumb/breadcrumb.component.d.ts +0 -16
- package/components/command-palette/command-palette.component.d.ts +0 -38
- package/components/command-palette/shortcut/shortcut.component.d.ts +0 -9
- package/components/dynamic-html/dynamic-html.component.d.ts +0 -15
- package/components/dynamic-html/dynamic-html.module.d.ts +0 -10
- package/components/dynamic-html/dynamic-html.service.d.ts +0 -18
- package/components/dynamic-html/types.d.ts +0 -12
- package/components/filemanager/file-grid/file-grid.component.d.ts +0 -101
- package/components/filemanager/filemanager.component.d.ts +0 -207
- package/components/filemanager/folder-rename/folder-rename.component.d.ts +0 -18
- package/components/filemanager/helpers.d.ts +0 -5
- package/components/filemanager/icon-resolver.d.ts +0 -13
- package/components/filemanager/textextensions.d.ts +0 -3
- package/components/filemanager/toolbar/breadcrumb/breadcrumb.component.d.ts +0 -16
- package/components/filemanager/toolbar/icon-button/icon-button.component.d.ts +0 -11
- package/components/filemanager/toolbar/toolbar.component.d.ts +0 -31
- package/components/filemanager/tree-view/tree-view.component.d.ts +0 -21
- package/components/react-magic-wrapper/react-magic-wrapper.component.d.ts +0 -63
- package/components/tabulator/tabulator.component.d.ts +0 -30
- package/components/vscode/ts-type-resolver/dependency-parser.d.ts +0 -6
- package/components/vscode/ts-type-resolver/dummy-source-cache.d.ts +0 -7
- package/components/vscode/ts-type-resolver/import-resolver.d.ts +0 -28
- package/components/vscode/ts-type-resolver/main.d.ts +0 -22
- package/components/vscode/ts-type-resolver/recursion-depth.d.ts +0 -11
- package/components/vscode/ts-type-resolver/types.d.ts +0 -179
- package/components/vscode/ts-type-resolver/unpkg-source-resolver.d.ts +0 -5
- package/components/vscode/ts-type-resolver/update-emitter.d.ts +0 -2
- package/components/vscode/vscode.component.d.ts +0 -52
- package/esm2022/assets/mat-icons.mjs +0 -5705
- package/esm2022/components/command-palette/breadcrumb/breadcrumb.component.mjs +0 -30
- package/esm2022/components/command-palette/command-palette.component.mjs +0 -257
- package/esm2022/components/command-palette/shortcut/shortcut.component.mjs +0 -19
- package/esm2022/components/dynamic-html/dynamic-html.component.mjs +0 -43
- package/esm2022/components/dynamic-html/dynamic-html.module.mjs +0 -27
- package/esm2022/components/dynamic-html/dynamic-html.service.mjs +0 -66
- package/esm2022/components/dynamic-html/types.mjs +0 -7
- package/esm2022/components/filemanager/file-grid/file-grid.component.mjs +0 -674
- package/esm2022/components/filemanager/filemanager.component.mjs +0 -314
- package/esm2022/components/filemanager/folder-rename/folder-rename.component.mjs +0 -57
- package/esm2022/components/filemanager/helpers.mjs +0 -26
- package/esm2022/components/filemanager/icon-resolver.mjs +0 -155
- package/esm2022/components/filemanager/textextensions.mjs +0 -294
- package/esm2022/components/filemanager/toolbar/breadcrumb/breadcrumb.component.mjs +0 -22
- package/esm2022/components/filemanager/toolbar/icon-button/icon-button.component.mjs +0 -32
- package/esm2022/components/filemanager/toolbar/toolbar.component.mjs +0 -165
- package/esm2022/components/filemanager/tree-view/tree-view.component.mjs +0 -51
- package/esm2022/components/react-magic-wrapper/react-magic-wrapper.component.mjs +0 -160
- package/esm2022/components/tabulator/tabulator.component.mjs +0 -93
- package/esm2022/components/vscode/ts-type-resolver/dependency-parser.mjs +0 -91
- package/esm2022/components/vscode/ts-type-resolver/dummy-source-cache.mjs +0 -15
- package/esm2022/components/vscode/ts-type-resolver/import-resolver.mjs +0 -311
- package/esm2022/components/vscode/ts-type-resolver/main.mjs +0 -112
- package/esm2022/components/vscode/ts-type-resolver/recursion-depth.mjs +0 -21
- package/esm2022/components/vscode/ts-type-resolver/types.mjs +0 -14
- package/esm2022/components/vscode/ts-type-resolver/unpkg-source-resolver.mjs +0 -21
- package/esm2022/components/vscode/ts-type-resolver/update-emitter.mjs +0 -37
- package/esm2022/components/vscode/vscode.component.mjs +0 -232
- package/esm2022/services/command-palette.service.mjs +0 -209
- package/fesm2022/dotglitch-ngx-common-folder-rename.component-6j7OjwOo.mjs +0 -83
- package/fesm2022/dotglitch-ngx-common-folder-rename.component-6j7OjwOo.mjs.map +0 -1
- package/services/command-palette.service.d.ts +0 -128
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
export const invokeUpdate = (progress, options) => {
|
|
2
|
-
let textual = `${progress.type}: `;
|
|
3
|
-
switch (progress.type) {
|
|
4
|
-
case 'CodeChanged':
|
|
5
|
-
textual += ``;
|
|
6
|
-
break;
|
|
7
|
-
case 'ResolveNewImports':
|
|
8
|
-
textual += ``;
|
|
9
|
-
break;
|
|
10
|
-
// case 'DetectedImport':
|
|
11
|
-
// textual += `at "${progress.source}" the import "${progress.importPath}" was detected`;
|
|
12
|
-
// break;
|
|
13
|
-
// case 'CompletedImport':
|
|
14
|
-
// textual += `at "${progress.source}" the import "${progress.importPath}" was completed`;
|
|
15
|
-
// break;
|
|
16
|
-
case 'LookedUpTypeFile':
|
|
17
|
-
textual += `"${progress.path}" was ${progress.success ? 'sucessfully' : 'not sucessfully'} looked up`;
|
|
18
|
-
break;
|
|
19
|
-
case 'AttemptedLookUpFile':
|
|
20
|
-
textual += `"${progress.path}" was ${progress.success ? 'sucessfully' : 'not sucessfully'} attempted to looked up`; // What in the hell is this grammar?
|
|
21
|
-
break;
|
|
22
|
-
case 'LookedUpPackage':
|
|
23
|
-
textual += `package.json for package "${progress.package}" was ${progress.success ? 'sucessfully' : 'not sucessfully'} looked up${progress.definitelyTyped ? ' (found in definitely typed repo)' : ''}`;
|
|
24
|
-
break;
|
|
25
|
-
case 'LoadedFromCache':
|
|
26
|
-
textual += `"${progress.importPath}" was loaded from cache`;
|
|
27
|
-
break;
|
|
28
|
-
case 'StoredToCache':
|
|
29
|
-
textual += `"${progress.importPath}" was stored to cache`;
|
|
30
|
-
break;
|
|
31
|
-
}
|
|
32
|
-
if (textual.endsWith(': ')) {
|
|
33
|
-
textual = textual.slice(undefined, -2);
|
|
34
|
-
}
|
|
35
|
-
options.onUpdate?.(progress, textual);
|
|
36
|
-
};
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBkYXRlLWVtaXR0ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21tb24vc3JjL2NvbXBvbmVudHMvdnNjb2RlL3RzLXR5cGUtcmVzb2x2ZXIvdXBkYXRlLWVtaXR0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUFHLENBQUMsUUFBd0IsRUFBRSxPQUFnQixFQUFFLEVBQUU7SUFDdkUsSUFBSSxPQUFPLEdBQUcsR0FBRyxRQUFRLENBQUMsSUFBSSxJQUFJLENBQUM7SUFFbkMsUUFBUSxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDcEIsS0FBSyxhQUFhO1lBQ2QsT0FBTyxJQUFJLEVBQUUsQ0FBQztZQUNkLE1BQU07UUFDVixLQUFLLG1CQUFtQjtZQUNwQixPQUFPLElBQUksRUFBRSxDQUFDO1lBQ2QsTUFBTTtRQUNWLHlCQUF5QjtRQUN6Qiw2RkFBNkY7UUFDN0YsYUFBYTtRQUNiLDBCQUEwQjtRQUMxQiw4RkFBOEY7UUFDOUYsYUFBYTtRQUNiLEtBQUssa0JBQWtCO1lBQ25CLE9BQU8sSUFBSSxJQUFJLFFBQVEsQ0FBQyxJQUFJLFNBQVMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQyxpQkFBaUIsWUFBWSxDQUFDO1lBQ3RHLE1BQU07UUFDVixLQUFLLHFCQUFxQjtZQUN0QixPQUFPLElBQUksSUFBSSxRQUFRLENBQUMsSUFBSSxTQUN4QixRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDLGlCQUN2Qyx5QkFBeUIsQ0FBQyxDQUFDLG9DQUFvQztZQUMvRCxNQUFNO1FBQ1YsS0FBSyxpQkFBaUI7WUFDbEIsT0FBTyxJQUFJLDZCQUE2QixRQUFRLENBQUMsT0FBTyxTQUNwRCxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDLGlCQUN2QyxhQUFhLFFBQVEsQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLG1DQUFtQyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQztZQUNuRixNQUFNO1FBQ1YsS0FBSyxpQkFBaUI7WUFDbEIsT0FBTyxJQUFJLElBQUksUUFBUSxDQUFDLFVBQVUseUJBQXlCLENBQUM7WUFDNUQsTUFBTTtRQUNWLEtBQUssZUFBZTtZQUNoQixPQUFPLElBQUksSUFBSSxRQUFRLENBQUMsVUFBVSx1QkFBdUIsQ0FBQztZQUMxRCxNQUFNO0lBQ2QsQ0FBQztJQUVELElBQUksT0FBTyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDO1FBQ3pCLE9BQU8sR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQzNDLENBQUM7SUFFRCxPQUFPLENBQUMsUUFBUSxFQUFFLENBQUMsUUFBUSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0FBQzFDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFByb2dyZXNzVXBkYXRlLCBPcHRpb25zIH0gZnJvbSAnLi90eXBlcyc7XG5cbmV4cG9ydCBjb25zdCBpbnZva2VVcGRhdGUgPSAocHJvZ3Jlc3M6IFByb2dyZXNzVXBkYXRlLCBvcHRpb25zOiBPcHRpb25zKSA9PiB7XG4gICAgbGV0IHRleHR1YWwgPSBgJHtwcm9ncmVzcy50eXBlfTogYDtcblxuICAgIHN3aXRjaCAocHJvZ3Jlc3MudHlwZSkge1xuICAgICAgICBjYXNlICdDb2RlQ2hhbmdlZCc6XG4gICAgICAgICAgICB0ZXh0dWFsICs9IGBgO1xuICAgICAgICAgICAgYnJlYWs7XG4gICAgICAgIGNhc2UgJ1Jlc29sdmVOZXdJbXBvcnRzJzpcbiAgICAgICAgICAgIHRleHR1YWwgKz0gYGA7XG4gICAgICAgICAgICBicmVhaztcbiAgICAgICAgLy8gY2FzZSAnRGV0ZWN0ZWRJbXBvcnQnOlxuICAgICAgICAvLyAgICAgdGV4dHVhbCArPSBgYXQgXCIke3Byb2dyZXNzLnNvdXJjZX1cIiB0aGUgaW1wb3J0IFwiJHtwcm9ncmVzcy5pbXBvcnRQYXRofVwiIHdhcyBkZXRlY3RlZGA7XG4gICAgICAgIC8vICAgICBicmVhaztcbiAgICAgICAgLy8gY2FzZSAnQ29tcGxldGVkSW1wb3J0JzpcbiAgICAgICAgLy8gICAgIHRleHR1YWwgKz0gYGF0IFwiJHtwcm9ncmVzcy5zb3VyY2V9XCIgdGhlIGltcG9ydCBcIiR7cHJvZ3Jlc3MuaW1wb3J0UGF0aH1cIiB3YXMgY29tcGxldGVkYDtcbiAgICAgICAgLy8gICAgIGJyZWFrO1xuICAgICAgICBjYXNlICdMb29rZWRVcFR5cGVGaWxlJzpcbiAgICAgICAgICAgIHRleHR1YWwgKz0gYFwiJHtwcm9ncmVzcy5wYXRofVwiIHdhcyAke3Byb2dyZXNzLnN1Y2Nlc3MgPyAnc3VjZXNzZnVsbHknIDogJ25vdCBzdWNlc3NmdWxseSd9IGxvb2tlZCB1cGA7XG4gICAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSAnQXR0ZW1wdGVkTG9va1VwRmlsZSc6XG4gICAgICAgICAgICB0ZXh0dWFsICs9IGBcIiR7cHJvZ3Jlc3MucGF0aH1cIiB3YXMgJHtcbiAgICAgICAgICAgICAgICBwcm9ncmVzcy5zdWNjZXNzID8gJ3N1Y2Vzc2Z1bGx5JyA6ICdub3Qgc3VjZXNzZnVsbHknXG4gICAgICAgICAgICB9IGF0dGVtcHRlZCB0byBsb29rZWQgdXBgOyAvLyBXaGF0IGluIHRoZSBoZWxsIGlzIHRoaXMgZ3JhbW1hcj9cbiAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICBjYXNlICdMb29rZWRVcFBhY2thZ2UnOlxuICAgICAgICAgICAgdGV4dHVhbCArPSBgcGFja2FnZS5qc29uIGZvciBwYWNrYWdlIFwiJHtwcm9ncmVzcy5wYWNrYWdlfVwiIHdhcyAke1xuICAgICAgICAgICAgICAgIHByb2dyZXNzLnN1Y2Nlc3MgPyAnc3VjZXNzZnVsbHknIDogJ25vdCBzdWNlc3NmdWxseSdcbiAgICAgICAgICAgIH0gbG9va2VkIHVwJHtwcm9ncmVzcy5kZWZpbml0ZWx5VHlwZWQgPyAnIChmb3VuZCBpbiBkZWZpbml0ZWx5IHR5cGVkIHJlcG8pJyA6ICcnfWA7XG4gICAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSAnTG9hZGVkRnJvbUNhY2hlJzpcbiAgICAgICAgICAgIHRleHR1YWwgKz0gYFwiJHtwcm9ncmVzcy5pbXBvcnRQYXRofVwiIHdhcyBsb2FkZWQgZnJvbSBjYWNoZWA7XG4gICAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSAnU3RvcmVkVG9DYWNoZSc6XG4gICAgICAgICAgICB0ZXh0dWFsICs9IGBcIiR7cHJvZ3Jlc3MuaW1wb3J0UGF0aH1cIiB3YXMgc3RvcmVkIHRvIGNhY2hlYDtcbiAgICAgICAgICAgIGJyZWFrO1xuICAgIH1cblxuICAgIGlmICh0ZXh0dWFsLmVuZHNXaXRoKCc6ICcpKSB7XG4gICAgICAgIHRleHR1YWwgPSB0ZXh0dWFsLnNsaWNlKHVuZGVmaW5lZCwgLTIpO1xuICAgIH1cblxuICAgIG9wdGlvbnMub25VcGRhdGU/Lihwcm9ncmVzcywgdGV4dHVhbCk7XG59O1xuIl19
|
|
@@ -1,232 +0,0 @@
|
|
|
1
|
-
import { Component, EventEmitter, HostListener, Input, Output } from '@angular/core';
|
|
2
|
-
import { MonacoAutoTypeImporter } from './ts-type-resolver/main';
|
|
3
|
-
import { debounceTime } from 'rxjs';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
let Monaco;
|
|
6
|
-
export class VscodeComponent {
|
|
7
|
-
set code(value) {
|
|
8
|
-
if (value == this._code)
|
|
9
|
-
return;
|
|
10
|
-
if (typeof value != "string")
|
|
11
|
-
throw new TypeError("Value must be of type string");
|
|
12
|
-
this._code = value;
|
|
13
|
-
this.editor?.setValue(this.code);
|
|
14
|
-
}
|
|
15
|
-
;
|
|
16
|
-
get code() { return this._code?.trim(); }
|
|
17
|
-
set language(value) {
|
|
18
|
-
this._language = {
|
|
19
|
-
'ts': "typescript",
|
|
20
|
-
'html': 'xml',
|
|
21
|
-
'scss': 'css'
|
|
22
|
-
}[value] || value || "auto";
|
|
23
|
-
}
|
|
24
|
-
get language() { return this._language; }
|
|
25
|
-
get settings() {
|
|
26
|
-
return {
|
|
27
|
-
...this.restSettings,
|
|
28
|
-
theme: this.theme,
|
|
29
|
-
language: this.language,
|
|
30
|
-
tabSize: this.tabSize,
|
|
31
|
-
readOnly: this.readOnly,
|
|
32
|
-
fontFamily: this.fontFamily,
|
|
33
|
-
fontSize: this.fontSize,
|
|
34
|
-
automaticLayout: this.automaticLayout,
|
|
35
|
-
scrollBeyondLastLine: this.scrollBeyondLastLine,
|
|
36
|
-
colorDecorators: this.colorDecorators,
|
|
37
|
-
folding: this.folding,
|
|
38
|
-
scrollBeyondLastColumn: this.scrollBeyondLastColumn,
|
|
39
|
-
minimap: this.minimap,
|
|
40
|
-
scrollbar: this.scrollbar,
|
|
41
|
-
smoothScrolling: this.smoothScrolling,
|
|
42
|
-
mouseWheelScrollSensitivity: this.mouseWheelScrollSensitivity,
|
|
43
|
-
lineNumbers: this.lineNumbers
|
|
44
|
-
};
|
|
45
|
-
}
|
|
46
|
-
constructor(viewContainer) {
|
|
47
|
-
this.viewContainer = viewContainer;
|
|
48
|
-
this.isDirty = false;
|
|
49
|
-
this.codeChange = new EventEmitter();
|
|
50
|
-
this.onCodeType = new EventEmitter();
|
|
51
|
-
this.typeDebounce = this.onCodeType.pipe(debounceTime(100));
|
|
52
|
-
this.installationLocation = "/lib/monaco/vs";
|
|
53
|
-
this.tabSize = 2;
|
|
54
|
-
this.readOnly = false;
|
|
55
|
-
this.theme = "vs-dark";
|
|
56
|
-
this.fontFamily = "Droid Sans Mono";
|
|
57
|
-
this.fontSize = 14;
|
|
58
|
-
this.automaticLayout = true;
|
|
59
|
-
this.colorDecorators = true;
|
|
60
|
-
this.folding = true;
|
|
61
|
-
this.minimapEnabled = true;
|
|
62
|
-
this.minimap = {
|
|
63
|
-
enabled: true
|
|
64
|
-
};
|
|
65
|
-
this.scrollbar = {
|
|
66
|
-
alwaysConsumeMouseWheel: false,
|
|
67
|
-
// scrollByPage: true
|
|
68
|
-
};
|
|
69
|
-
this.smoothScrolling = true;
|
|
70
|
-
this.mouseWheelScrollSensitivity = 2;
|
|
71
|
-
this.scrollBeyondLastLine = false;
|
|
72
|
-
this.scrollBeyondLastColumn = 0;
|
|
73
|
-
this.lineNumbers = "on";
|
|
74
|
-
this.restSettings = {};
|
|
75
|
-
this.resize = () => {
|
|
76
|
-
this.editor?.layout();
|
|
77
|
-
};
|
|
78
|
-
InstallMonacoUMD(this.installationLocation);
|
|
79
|
-
this._sub = this.typeDebounce.subscribe(t => {
|
|
80
|
-
this.codeChange.next(this._code = this.editor.getValue());
|
|
81
|
-
});
|
|
82
|
-
}
|
|
83
|
-
ngOnChanges(changes) {
|
|
84
|
-
// If we changed anything OTHER than code, reload the editor
|
|
85
|
-
if (Object.keys(changes).length > 1 || !changes['code']) {
|
|
86
|
-
if (this.editor) {
|
|
87
|
-
this.editor?.dispose();
|
|
88
|
-
this.createEditor();
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
if (changes['theme'])
|
|
92
|
-
window['monaco']?.editor.setTheme(this.theme);
|
|
93
|
-
}
|
|
94
|
-
async ngAfterViewInit() {
|
|
95
|
-
await InstallMonacoUMD();
|
|
96
|
-
this.createEditor();
|
|
97
|
-
}
|
|
98
|
-
ngOnDestroy() {
|
|
99
|
-
this.editor?.dispose();
|
|
100
|
-
this._sub?.unsubscribe();
|
|
101
|
-
}
|
|
102
|
-
createEditor() {
|
|
103
|
-
if (this.customLanguage) {
|
|
104
|
-
this.customLanguage.init(window['monaco']);
|
|
105
|
-
}
|
|
106
|
-
let editor = this.editor = window['monaco'].editor.create(this.viewContainer?.element?.nativeElement, this.settings);
|
|
107
|
-
// const autoTypings = await
|
|
108
|
-
MonacoAutoTypeImporter.create(editor, {
|
|
109
|
-
monaco: Monaco,
|
|
110
|
-
});
|
|
111
|
-
this.configureLanguageSupport();
|
|
112
|
-
if (this.code) {
|
|
113
|
-
editor.setValue(this.code);
|
|
114
|
-
}
|
|
115
|
-
editor.getModel().onDidChangeContent(() => this.onCodeType.emit());
|
|
116
|
-
}
|
|
117
|
-
configureLanguageSupport() {
|
|
118
|
-
}
|
|
119
|
-
download() {
|
|
120
|
-
const code = this.editor.getValue();
|
|
121
|
-
let blob = new Blob([code], { type: 'text/log' });
|
|
122
|
-
let elm = document.createElement('a');
|
|
123
|
-
let blobURL = URL.createObjectURL(blob);
|
|
124
|
-
// Set the data values.
|
|
125
|
-
elm.href = blobURL;
|
|
126
|
-
elm.download = this.filename;
|
|
127
|
-
document.body.appendChild(elm);
|
|
128
|
-
elm.click();
|
|
129
|
-
document.body.removeChild(elm);
|
|
130
|
-
elm.remove();
|
|
131
|
-
URL.revokeObjectURL(blobURL);
|
|
132
|
-
}
|
|
133
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: VscodeComponent, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
134
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", 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"] }); }
|
|
135
|
-
}
|
|
136
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: VscodeComponent, decorators: [{
|
|
137
|
-
type: Component,
|
|
138
|
-
args: [{ selector: 'app-vscode', template: '', standalone: true, styles: [":host{display:block;height:100%;max-height:100vh;max-width:100vw}\n"] }]
|
|
139
|
-
}], ctorParameters: () => [{ type: i0.ViewContainerRef }], propDecorators: { code: [{
|
|
140
|
-
type: Input
|
|
141
|
-
}], codeChange: [{
|
|
142
|
-
type: Output
|
|
143
|
-
}], customLanguage: [{
|
|
144
|
-
type: Input
|
|
145
|
-
}], language: [{
|
|
146
|
-
type: Input
|
|
147
|
-
}], installationLocation: [{
|
|
148
|
-
type: Input
|
|
149
|
-
}], tabSize: [{
|
|
150
|
-
type: Input
|
|
151
|
-
}], readOnly: [{
|
|
152
|
-
type: Input
|
|
153
|
-
}], theme: [{
|
|
154
|
-
type: Input
|
|
155
|
-
}], fontFamily: [{
|
|
156
|
-
type: Input
|
|
157
|
-
}], fontSize: [{
|
|
158
|
-
type: Input
|
|
159
|
-
}], automaticLayout: [{
|
|
160
|
-
type: Input
|
|
161
|
-
}], colorDecorators: [{
|
|
162
|
-
type: Input
|
|
163
|
-
}], folding: [{
|
|
164
|
-
type: Input
|
|
165
|
-
}], minimapEnabled: [{
|
|
166
|
-
type: Input
|
|
167
|
-
}], minimap: [{
|
|
168
|
-
type: Input
|
|
169
|
-
}], scrollbar: [{
|
|
170
|
-
type: Input
|
|
171
|
-
}], smoothScrolling: [{
|
|
172
|
-
type: Input
|
|
173
|
-
}], mouseWheelScrollSensitivity: [{
|
|
174
|
-
type: Input
|
|
175
|
-
}], scrollBeyondLastLine: [{
|
|
176
|
-
type: Input
|
|
177
|
-
}], scrollBeyondLastColumn: [{
|
|
178
|
-
type: Input
|
|
179
|
-
}], lineNumbers: [{
|
|
180
|
-
type: Input
|
|
181
|
-
}], restSettings: [{
|
|
182
|
-
type: Input
|
|
183
|
-
}], resize: [{
|
|
184
|
-
type: HostListener,
|
|
185
|
-
args: ['window:resize', ['$event']]
|
|
186
|
-
}] } });
|
|
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
|
-
res(true);
|
|
224
|
-
}
|
|
225
|
-
else if (count >= 100) {
|
|
226
|
-
window.clearInterval(i);
|
|
227
|
-
res(false);
|
|
228
|
-
}
|
|
229
|
-
}, 100);
|
|
230
|
-
});
|
|
231
|
-
};
|
|
232
|
-
//# 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        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            window['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(window['monaco']);\r\n        }\r\n\r\n        let editor = this.editor = window['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                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"]}
|
|
@@ -1,209 +0,0 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import { ConsoleLogger, LogIcon } from '../utils';
|
|
3
|
-
import { CommandPaletteComponent } from '../components/command-palette/command-palette.component';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "@angular/material/dialog";
|
|
6
|
-
import * as i2 from "../components/lazy-loader/lazy-loader.service";
|
|
7
|
-
const { log, warn, err } = ConsoleLogger("CommandPalette", "#2196f3");
|
|
8
|
-
export class CommandPaletteService {
|
|
9
|
-
constructor(dialog, lazyLoader) {
|
|
10
|
-
this.dialog = dialog;
|
|
11
|
-
this.lazyLoader = lazyLoader;
|
|
12
|
-
this.commandBlocks = [];
|
|
13
|
-
window.addEventListener("keydown", (evt) => this.onKeyDown(evt));
|
|
14
|
-
this.interval = setInterval(() => {
|
|
15
|
-
// Go backwards since we're splicing items out of the array.
|
|
16
|
-
for (let i = this.commandBlocks.length; i >= 0; i--) {
|
|
17
|
-
let commandBlock = this.commandBlocks[i];
|
|
18
|
-
// If the current index is somehow null, rip it out of
|
|
19
|
-
// the array and wait for cleanup to trigger again
|
|
20
|
-
// for the rest of the array.
|
|
21
|
-
// TODO: Could this lead to leaks where things at the end
|
|
22
|
-
// never get cleaned?
|
|
23
|
-
if (commandBlock == null) {
|
|
24
|
-
this.commandBlocks.splice(i, 1);
|
|
25
|
-
return;
|
|
26
|
-
}
|
|
27
|
-
// If the element has been disconnected from the DOM, we will
|
|
28
|
-
// treat it as having been permanently removed.
|
|
29
|
-
// TODO: Could this ever cause unintended consequences?
|
|
30
|
-
if (!commandBlock?.element.isConnected)
|
|
31
|
-
this.commandBlocks.splice(i, 1);
|
|
32
|
-
}
|
|
33
|
-
}, 5 * 60 * 1000);
|
|
34
|
-
}
|
|
35
|
-
ngOnDestroy() {
|
|
36
|
-
clearInterval(this.interval);
|
|
37
|
-
}
|
|
38
|
-
getCommandBlocks(element = document.body) {
|
|
39
|
-
const elementPath = [element];
|
|
40
|
-
let currentTarget = element;
|
|
41
|
-
do {
|
|
42
|
-
elementPath.unshift(currentTarget = currentTarget.parentElement);
|
|
43
|
-
} while (currentTarget.parentElement);
|
|
44
|
-
// Ordered matching command blocks, closest first
|
|
45
|
-
const matchingCommandBlocks = [];
|
|
46
|
-
for (const element of elementPath) {
|
|
47
|
-
const commandBlock = this.commandBlocks.find(cb => cb.element == element);
|
|
48
|
-
if (commandBlock) {
|
|
49
|
-
matchingCommandBlocks.unshift(commandBlock);
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
return matchingCommandBlocks;
|
|
53
|
-
}
|
|
54
|
-
/**
|
|
55
|
-
* Handle keydown events
|
|
56
|
-
*
|
|
57
|
-
* If an event has been removed from the DOM tree, we don't need
|
|
58
|
-
* to explicitly remove the bindings, as they will never fire
|
|
59
|
-
*
|
|
60
|
-
* We periodically check and remove unconnected command blocks
|
|
61
|
-
*/
|
|
62
|
-
onKeyDown(evt) {
|
|
63
|
-
const matchingCommandBlocks = this.getCommandBlocks(evt.target);
|
|
64
|
-
// String in format `ctrl+alt+F`, `ctrl+F` etc.
|
|
65
|
-
const key = [
|
|
66
|
-
evt.ctrlKey ? "ctrl" : undefined,
|
|
67
|
-
evt.altKey ? "alt" : undefined,
|
|
68
|
-
evt.shiftKey ? "shift" : undefined,
|
|
69
|
-
evt.metaKey ? "meta" : undefined,
|
|
70
|
-
evt.code.startsWith("Key") ? evt.key : evt.code
|
|
71
|
-
].filter(a => a).join('+').toLowerCase();
|
|
72
|
-
for (const commandBlock of matchingCommandBlocks) {
|
|
73
|
-
const action = commandBlock.actions.find(a => {
|
|
74
|
-
return Array.isArray(a.shortcutKey)
|
|
75
|
-
? a.shortcutKey.includes(key)
|
|
76
|
-
: a.shortcutKey == key;
|
|
77
|
-
});
|
|
78
|
-
if (action) {
|
|
79
|
-
evt.stopPropagation();
|
|
80
|
-
evt.preventDefault();
|
|
81
|
-
this.invokeAction(action);
|
|
82
|
-
// Execute the action and move on.
|
|
83
|
-
return;
|
|
84
|
-
}
|
|
85
|
-
// Keep checking for matching actions
|
|
86
|
-
}
|
|
87
|
-
// If execution reaches this point, there were no matching actions on the
|
|
88
|
-
// path of elements that were registered.
|
|
89
|
-
}
|
|
90
|
-
addCommand(element, action) {
|
|
91
|
-
const commandBlock = this.commandBlocks.find(b => b.element == element) ?? (() => {
|
|
92
|
-
const cb = { element, actions: [] };
|
|
93
|
-
this.commandBlocks.push(cb);
|
|
94
|
-
return cb;
|
|
95
|
-
})();
|
|
96
|
-
// This is likely a duplicate entry
|
|
97
|
-
if (commandBlock.actions.find(a => a.shortcutKey && a.shortcutKey == action.shortcutKey)) {
|
|
98
|
-
warn(`Inserting duplicate action on element`, { element, action });
|
|
99
|
-
}
|
|
100
|
-
else {
|
|
101
|
-
// log(LogIcon.circle_blue, `Inserted action`, action)
|
|
102
|
-
}
|
|
103
|
-
// Make the shortcut keys lowercase so case sensitivity doesn't scalp someone
|
|
104
|
-
if (action.shortcutKey) {
|
|
105
|
-
if (Array.isArray(action.shortcutKey))
|
|
106
|
-
action.shortcutKey = action.shortcutKey.map(k => k.toLowerCase());
|
|
107
|
-
else
|
|
108
|
-
action.shortcutKey = action.shortcutKey.toLowerCase();
|
|
109
|
-
}
|
|
110
|
-
commandBlock.actions.push(action);
|
|
111
|
-
}
|
|
112
|
-
removeCommand(element, action) {
|
|
113
|
-
const commandBlock = this.commandBlocks.find(b => b.element == element) ?? { element, actions: [] };
|
|
114
|
-
const actionIndex = commandBlock?.actions.findIndex(a => typeof action == "string" ? a.shortcutKey == action : a == action);
|
|
115
|
-
if (!commandBlock) {
|
|
116
|
-
err(LogIcon.warning, `Cannot remove command: element does not have any commands registered`, { element, action });
|
|
117
|
-
}
|
|
118
|
-
else if (actionIndex == -1) {
|
|
119
|
-
warn(LogIcon.warning, `Cannot remove command: not present in list`, { element, action });
|
|
120
|
-
}
|
|
121
|
-
else {
|
|
122
|
-
commandBlock.actions.splice(actionIndex, 1);
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
/**
|
|
126
|
-
*
|
|
127
|
-
*/
|
|
128
|
-
initialize(options) {
|
|
129
|
-
this.attachElementCommands([
|
|
130
|
-
{
|
|
131
|
-
shortcutKey: options.keybind,
|
|
132
|
-
action: () => this.openPalette(),
|
|
133
|
-
description: "Open the command palette",
|
|
134
|
-
keywords: ["command", "prompt", "console", "actions"],
|
|
135
|
-
label: "Command Palette",
|
|
136
|
-
visibleInList: false
|
|
137
|
-
}
|
|
138
|
-
]);
|
|
139
|
-
}
|
|
140
|
-
/**
|
|
141
|
-
* Open the command palette
|
|
142
|
-
*/
|
|
143
|
-
openPalette() {
|
|
144
|
-
return this.dialog.open(CommandPaletteComponent, {
|
|
145
|
-
position: {
|
|
146
|
-
top: "8px"
|
|
147
|
-
},
|
|
148
|
-
data: {
|
|
149
|
-
contextElement: document.activeElement
|
|
150
|
-
},
|
|
151
|
-
panelClass: ['ngx-command-palette'],
|
|
152
|
-
backdropClass: ['ngx-command-palette'],
|
|
153
|
-
restoreFocus: true,
|
|
154
|
-
role: 'dialog'
|
|
155
|
-
});
|
|
156
|
-
}
|
|
157
|
-
/**
|
|
158
|
-
* Public helper to invoke an action.
|
|
159
|
-
*/
|
|
160
|
-
invokeAction(action, args) {
|
|
161
|
-
const fn = action.action;
|
|
162
|
-
if (typeof fn == 'function') {
|
|
163
|
-
try {
|
|
164
|
-
const res = fn(args);
|
|
165
|
-
// Handle promises so that the GUI can show spinners for them
|
|
166
|
-
if (res instanceof Promise) {
|
|
167
|
-
// TODO
|
|
168
|
-
}
|
|
169
|
-
else {
|
|
170
|
-
// TODO
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
catch (ex) {
|
|
174
|
-
err(LogIcon.bomb, `Executing action threw an error`, { action }, ex);
|
|
175
|
-
}
|
|
176
|
-
}
|
|
177
|
-
else {
|
|
178
|
-
warn(LogIcon.warning, `Cannot execute action, type is not "function"`, { action });
|
|
179
|
-
}
|
|
180
|
-
}
|
|
181
|
-
attachElementCommands(element = document.body, actions = []) {
|
|
182
|
-
if (Array.isArray(element)) {
|
|
183
|
-
actions = element;
|
|
184
|
-
element = document.body;
|
|
185
|
-
}
|
|
186
|
-
actions.forEach(a => this.addCommand(element, a));
|
|
187
|
-
}
|
|
188
|
-
/**
|
|
189
|
-
* Detach specified commands from an Element subtree
|
|
190
|
-
*/
|
|
191
|
-
detachElementCommands(element = document.body, actions = []) {
|
|
192
|
-
actions.forEach(a => this.removeCommand(element, a));
|
|
193
|
-
}
|
|
194
|
-
/**
|
|
195
|
-
* Return the list of registered commands under a given element
|
|
196
|
-
*/
|
|
197
|
-
getRegisteredCommands(element = document.body) {
|
|
198
|
-
return this.getCommandBlocks(element).map(c => c.actions).flat();
|
|
199
|
-
}
|
|
200
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CommandPaletteService, deps: [{ token: i1.MatDialog }, { token: i2.LazyLoaderService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
201
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CommandPaletteService, providedIn: 'root' }); }
|
|
202
|
-
}
|
|
203
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CommandPaletteService, decorators: [{
|
|
204
|
-
type: Injectable,
|
|
205
|
-
args: [{
|
|
206
|
-
providedIn: 'root'
|
|
207
|
-
}]
|
|
208
|
-
}], ctorParameters: () => [{ type: i1.MatDialog }, { type: i2.LazyLoaderService }] });
|
|
209
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"command-palette.service.js","sourceRoot":"","sources":["../../../../packages/common/src/services/command-palette.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, HostListener, Type, isDevMode } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport { ConsoleLogger, LogIcon } from '../utils';\nimport { LazyLoaderService } from '../components/lazy-loader/lazy-loader.service';\nimport { CommandPaletteComponent } from '../components/command-palette/command-palette.component';\n\nconst { log, warn, err } = ConsoleLogger(\"CommandPalette\", \"#2196f3\");\n\ntype KeyCode = \"Backspace\" | \"Tab\" | \"Enter\" | \"ShiftLeft\" | \"ShiftRight\"\n    | \"ControlLeft\" | \"ControlRight\" | \"AltLeft\" | \"AltRight\" | \"Pause\" | \"CapsLock\"\n    | \"Escape\" | \"Space\" | \"PageUp\" | \"PageDown\" | \"End\" | \"Home\" | \"ArrowLeft\"\n    | \"ArrowUp\" | \"ArrowRight\" | \"ArrowDown\" | \"PrintScreen\" | \"Insert\" | \"Delete\"\n    | \"MetaLeft\" | \"MetaRight\" | \"ContextMenu\" | \"Numpad0\" | \"Numpad1\" | \"Numpad2\"\n    | \"Numpad3\" | \"Numpad4\" | \"Numpad5\" | \"Numpad6\" | \"Numpad7\" | \"Numpad8\"\n    | \"Numpad9\" | \"NumpadMultiply\" | \"NumpadAdd\" | \"NumpadSubtract\"\n    | \"NumpadDecimal\" | \"NumpadDivide\"\n    | \"F1\" | \"F2\" | \"F3\" | \"F4\" | \"F5\" | \"F6\" | \"F7\" | \"F8\" | \"F9\" | \"F10\" | \"F11\" | \"F12\"\n    | \"NumLock\" | \"ScrollLock\" | \"Semicolon\" | \"Equal\" | \"Comma\" | \"Minus\"\n    | \"Period\" | \"Slash\" | \"Backquote\" | \"BracketLeft\" | \"Backslash\"\n    | \"BracketRight\" | \"Quote\" | \"backspace\" | \"tab\" | \"enter\" | \"shiftleft\"\n    | \"shiftright\" | \"controlleft\" | \"controlright\" | \"altleft\" | \"altright\"\n    | \"pause\" | \"capslock\" | \"escape\" | \"space\" | \"pageup\" | \"pagedown\" | \"end\"\n    | \"home\" | \"arrowleft\" | \"arrowup\" | \"arrowright\" | \"arrowdown\" | \"printscreen\"\n    | \"insert\" | \"delete\" | \"metaleft\" | \"metaright\" | \"contextmenu\"\n    | \"numpad0\" | \"numpad1\" | \"numpad2\" | \"numpad3\" | \"numpad4\" | \"numpad5\"\n    | \"numpad6\" | \"numpad7\" | \"numpad8\" | \"numpad9\" | \"numpadmultiply\" | \"numpadadd\"\n    | \"numpadsubtract\" | \"numpaddecimal\" | \"numpaddivide\"\n    | \"f1\" | \"f2\" | \"f3\" | \"f4\" | \"f5\" | \"f6\" | \"f7\" | \"f8\" | \"f9\" | \"f10\" | \"f11\" | \"f12\"\n    | \"numlock\" | \"scrolllock\" | \"semicolon\" | \"equal\" | \"comma\" | \"minus\" | \"period\"\n    | \"slash\" | \"backquote\" | \"bracketleft\" | \"backslash\" | \"bracketright\" | \"quote\"\n    | \"A\" | \"B\" | \"C\" | \"D\" | \"E\" | \"F\" | \"G\" | \"H\" | \"I\" | \"J\" | \"K\" | \"L\" | \"M\"\n    | \"N\" | \"O\" | \"P\" | \"Q\" | \"R\" | \"S\" | \"T\" | \"U\" | \"V\" | \"W\" | \"X\" | \"Y\" | \"Z\"\n    | \"a\" | \"b\" | \"c\" | \"d\" | \"e\" | \"f\" | \"g\" | \"h\" | \"i\" | \"j\" | \"k\" | \"l\" | \"m\"\n    | \"n\" | \"o\" | \"p\" | \"q\" | \"r\" | \"s\" | \"t\" | \"u\" | \"v\" | \"w\" | \"x\" | \"y\" | \"z\";\n\n// ctrl+alt+meta+shift\ntype KeyPrefix =\n    `ctrl` |\n    `ctrl+alt` |\n    `ctrl+alt+shift` |\n    `ctrl+alt+shift+meta` |\n    `ctrl+alt+meta` |\n    `ctrl+shift` |\n    `ctrl+shift+meta` |\n    `ctrl+meta` |\n    `alt` |\n    `alt+shift` |\n    `alt+shift+meta` |\n    `alt+meta` |\n    `shift` |\n    `shift+meta` |\n    `meta`\n\nexport type KeybindEvent = (e: KeyboardEvent) => void;\nexport type KeybindCode = `${KeyPrefix}+${KeyCode}` | KeyCode;\n\n\n\nexport type CommandAction<T = any> = {\n    /**\n     * The non-modifier key(s) that must be pressed for the event to fire.\n     */\n    shortcutKey?: KeybindCode | KeybindCode[],\n\n    /**\n     * Action that is invoked when the keyboard shortcut is pressed or the item\n     * is activated in the GUI menu\n     * If the GUI menu is open, it will show a spinner if the action returns a `Promise`\n     */\n    action?: (evt: KeyboardEvent, data?: T) => Promise<any> | any,\n\n    /**\n     * Arbitrary data object to be passed into the action\n     */\n    data?: T,\n\n    /**\n     * Label in the command palette popup\n     */\n    label?: string,\n\n    /**\n     * Hint that follows the label, subtly\n     */\n    hint?: string,\n\n    /**\n     * Icon for the entry\n     * Can be a mat-icon\n     * Will be a mat-icon if the string is simple\n     * If the string contains a slash or colon, it will be loaded as\n     * an image source\n     */\n    icon?: string,\n\n    /**\n     * Keywords that can help pick this command\n     */\n    keywords?: string | string[],\n\n    /**\n     * Description for the popup\n     * WIP\n     */\n    description?: string,\n\n    /**\n     * The root ancestor element of the action\n     * (This allows scoping commands to specific HTML elements)\n     * This requires that the event target must be a descendant\n     *\n     * If there are multiple matching descendants, only\n     * the furthest descendant will be fired\n     *\n     * For command scoping, we read the data-label attribute\n     * Alternatively, you can set label and element as an object here.\n     */\n    rootElement?: HTMLElement | string | {\n        element: HTMLElement | string,\n        label: string\n    },\n\n    /**\n     * The label for the root. Used for the UI control and debugging.\n     */\n    rootName?: string,\n\n    /**\n     * Control whether this command action is visible in the popup command\n     * palette GUI.\n     */\n    visibleInList?: boolean,\n\n    /**\n     * Enable selecting an item to show a list of sub-items\n     */\n    subMenu?: CommandAction<T>[] | (() => Promise<CommandAction<T>[]>) | (() => CommandAction<T>[])\n\n};\n\ntype CommandBlock = {\n    element: HTMLElement,\n    actions: CommandAction[];\n};\n\nexport type CommandPaletteOptions = {\n    keybind: KeybindCode\n}\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class CommandPaletteService {\n\n    private commandBlocks: CommandBlock[] = [];\n    private interval;\n\n    constructor(\n        private readonly dialog: MatDialog,\n        private readonly lazyLoader: LazyLoaderService\n    ) {\n        window.addEventListener(\"keydown\", (evt) => this.onKeyDown(evt));\n\n        this.interval = setInterval(() => {\n            // Go backwards since we're splicing items out of the array.\n            for (let i = this.commandBlocks.length; i >= 0; i--) {\n                let commandBlock = this.commandBlocks[i];\n\n                // If the current index is somehow null, rip it out of\n                // the array and wait for cleanup to trigger again\n                // for the rest of the array.\n                // TODO: Could this lead to leaks where things at the end\n                // never get cleaned?\n                if (commandBlock == null) {\n                    this.commandBlocks.splice(i, 1);\n                    return;\n                }\n\n                // If the element has been disconnected from the DOM, we will\n                // treat it as having been permanently removed.\n                // TODO: Could this ever cause unintended consequences?\n                if (!commandBlock?.element.isConnected)\n                    this.commandBlocks.splice(i, 1);\n            }\n        }, 5 * 60 * 1000);\n    }\n\n    private ngOnDestroy() {\n        clearInterval(this.interval);\n    }\n\n    private getCommandBlocks(element: HTMLElement = document.body) {\n        const elementPath: HTMLElement[] = [element];\n        let currentTarget: HTMLElement = element;\n        do {\n            elementPath.unshift(currentTarget = currentTarget.parentElement);\n        } while (currentTarget.parentElement);\n\n        // Ordered matching command blocks, closest first\n        const matchingCommandBlocks: CommandBlock[] = [];\n        for (const element of elementPath) {\n            const commandBlock = this.commandBlocks.find(cb => cb.element == element);\n            if (commandBlock) {\n                matchingCommandBlocks.unshift(commandBlock);\n            }\n        }\n\n        return matchingCommandBlocks;\n    }\n\n    /**\n     * Handle keydown events\n     *\n     * If an event has been removed from the DOM tree, we don't need\n     * to explicitly remove the bindings, as they will never fire\n     *\n     * We periodically check and remove unconnected command blocks\n     */\n    private onKeyDown(evt: KeyboardEvent) {\n        const matchingCommandBlocks = this.getCommandBlocks(evt.target as HTMLElement);\n\n        // String in format `ctrl+alt+F`, `ctrl+F` etc.\n        const key = [\n            evt.ctrlKey ? \"ctrl\" : undefined,\n            evt.altKey ? \"alt\" : undefined,\n            evt.shiftKey ? \"shift\" : undefined,\n            evt.metaKey ? \"meta\" : undefined,\n            evt.code.startsWith(\"Key\") ? evt.key : evt.code\n        ].filter(a => a).join('+').toLowerCase();\n\n        for (const commandBlock of matchingCommandBlocks) {\n            const action = commandBlock.actions.find(a => {\n                return Array.isArray(a.shortcutKey)\n                    ? a.shortcutKey.includes(key as any)\n                    : a.shortcutKey == key as any\n            });\n\n            if (action) {\n                evt.stopPropagation();\n                evt.preventDefault();\n\n                this.invokeAction(action);\n\n                // Execute the action and move on.\n                return;\n            }\n            // Keep checking for matching actions\n        }\n\n        // If execution reaches this point, there were no matching actions on the\n        // path of elements that were registered.\n    }\n\n    private addCommand(element: HTMLElement, action: CommandAction) {\n        const commandBlock = this.commandBlocks.find(b => b.element == element) ?? (() => {\n            const cb = { element, actions: [] };\n            this.commandBlocks.push(cb);\n            return cb;\n        })();\n\n        // This is likely a duplicate entry\n        if (commandBlock.actions.find(a => a.shortcutKey && a.shortcutKey == action.shortcutKey)) {\n            warn(`Inserting duplicate action on element`, { element, action });\n        }\n        else {\n            // log(LogIcon.circle_blue, `Inserted action`, action)\n        }\n\n        // Make the shortcut keys lowercase so case sensitivity doesn't scalp someone\n        if (action.shortcutKey) {\n            if (Array.isArray(action.shortcutKey))\n                action.shortcutKey = action.shortcutKey.map(k => k.toLowerCase()) as any;\n            else\n                action.shortcutKey = action.shortcutKey.toLowerCase() as any;\n        }\n\n        commandBlock.actions.push(action);\n    }\n\n    private removeCommand(element: HTMLElement, action: CommandAction | string) {\n        const commandBlock = this.commandBlocks.find(b => b.element == element) ?? { element, actions: [] };\n        const actionIndex = commandBlock?.actions.findIndex(a => typeof action == \"string\" ? a.shortcutKey == action : a == action);\n\n        if (!commandBlock) {\n            err(LogIcon.warning, `Cannot remove command: element does not have any commands registered`, { element, action })\n        }\n        else if (actionIndex == -1) {\n            warn(LogIcon.warning, `Cannot remove command: not present in list`, { element, action })\n        }\n        else {\n            commandBlock.actions.splice(actionIndex, 1);\n        }\n    }\n\n    /**\n     *\n     */\n    initialize(options: CommandPaletteOptions) {\n        this.attachElementCommands([\n            {\n                shortcutKey: options.keybind,\n                action: () => this.openPalette(),\n                description: \"Open the command palette\",\n                keywords: [\"command\", \"prompt\", \"console\", \"actions\"],\n                label: \"Command Palette\",\n                visibleInList: false\n            }\n        ]);\n    }\n\n    /**\n     * Open the command palette\n     */\n    openPalette() {\n        return this.dialog.open(CommandPaletteComponent, {\n            position: {\n                top: \"8px\"\n            },\n            data: {\n                contextElement: document.activeElement\n            },\n            panelClass: ['ngx-command-palette'],\n            backdropClass: ['ngx-command-palette'],\n            restoreFocus: true,\n            role: 'dialog'\n        });\n    }\n\n    /**\n     * Public helper to invoke an action.\n     */\n    invokeAction(action: CommandAction, args?) {\n        const fn = action.action;\n        if (typeof fn == 'function') {\n\n            try {\n                const res = fn(args);\n\n                // Handle promises so that the GUI can show spinners for them\n                if (res instanceof Promise) {\n                    // TODO\n                }\n                else {\n                    // TODO\n                }\n            }\n            catch (ex) {\n                err(LogIcon.bomb, `Executing action threw an error`, { action }, ex);\n            }\n        }\n        else {\n            warn(LogIcon.warning, `Cannot execute action, type is not \"function\"`, { action });\n        }\n    }\n\n    /**\n     * Attach commands to an Element and it's subtree\n     */\n    attachElementCommands(actions: CommandAction[])\n    attachElementCommands(element: HTMLElement, actions: CommandAction[])\n    attachElementCommands(element: CommandAction[] | HTMLElement = document.body, actions: CommandAction[] = []) {\n        if (Array.isArray(element)) {\n            actions = element;\n            element = document.body;\n        }\n\n        actions.forEach(a => this.addCommand(element as any, a));\n    }\n\n    /**\n     * Detach specified commands from an Element subtree\n     */\n    detachElementCommands(element: HTMLElement = document.body, actions: CommandAction[] = []) {\n        actions.forEach(a => this.removeCommand(element, a));\n    }\n\n    /**\n     * Return the list of registered commands under a given element\n     */\n    getRegisteredCommands(element: HTMLElement = document.body) {\n        return this.getCommandBlocks(element).map(c => c.actions).flat();\n    }\n}\n"]}
|