@omegagrid/commands 0.6.116 → 0.6.118
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/dist/model/commands.d.ts +1 -0
- package/dist/model/commands.d.ts.map +1 -1
- package/dist/model/commands.js.map +1 -1
- package/dist/ui/commandWindow.d.ts +11 -1
- package/dist/ui/commandWindow.d.ts.map +1 -1
- package/dist/ui/commandWindow.js +57 -16
- package/dist/ui/commandWindow.js.map +1 -1
- package/package.json +2 -2
package/dist/model/commands.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"commands.d.ts","sourceRoot":"","sources":["../../src/model/commands.ts"],"names":[],"mappings":"AAEA,MAAM,MAAM,eAAe,GAAG,CAAC,GAAG,MAAM,EAAE,MAAM,EAAE,KAAK,IAAI,CAAC;AAE5D,qBAAa,cAAc;aAMT,EAAE,EAAE,MAAM;aACV,IAAI,EAAE,MAAM;IAL7B,SAAgB,QAAQ,uBAA8B;IAC/C,IAAI,UAAQ;gBAGF,EAAE,EAAE,MAAM,EACV,IAAI,EAAE,MAAM;IAG7B,UAAU,CAAC,OAAO,EAAE,OAAO;CAI3B;AAED,qBAAa,OAAO;IAEnB,SAAgB,EAAE,EAAE,MAAM,CAAC;IAC3B,SAAgB,IAAI,EAAE,MAAM,CAAC;IAC7B,SAAgB,OAAO,EAAE,MAAM,CAAC;IAChC,SAAgB,EAAE,EAAE,eAAe,CAAC;IACpC,SAAgB,cAAc,EAAE,MAAM,CAAC;gBAE3B,OAAO,EAAE,OAAO,CAAC,OAAO,CAAC;IAMrC,IAAI,CAAC,GAAG,MAAM,EAAE,MAAM,EAAE;CAIxB;AAED,qBAAa,QAAQ;IAEpB,SAAgB,QAAQ,8BAAqC;IAE7D,IAAI,KAAK,WAIR;gBAEW,QAAQ,CAAC,EAAE,OAAO,CAAC,OAAO,CAAC,EAAE;IAIzC,KAAK;IAKL,eAAe,CAAC,OAAO,EAAE,OAAO,CAAC,cAAc,CAAC,EAAE,MAAM,UAAO;IAO/D,aAAa,CAAC,SAAS,EAAE,MAAM;IAI/B,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC,OAAO,CAAC;IAMlC,MAAM,CAAC,IAAI,EAAE,MAAM;IAInB,GAAG,CAAC,IAAI,EAAE,MAAM;IAOhB,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,MAAM,EAAE;IAIzC,MAAM,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,eAAe,UAAQ,EAAE,aAAa,UAAQ,GAAG,CAAC,cAAc,GAAC,OAAO,CAAC,EAAE;IA0BjG,KAAK,CAAC,QAAQ,EAAE,QAAQ,GAAG,QAAQ;CAOnC"}
|
|
1
|
+
{"version":3,"file":"commands.d.ts","sourceRoot":"","sources":["../../src/model/commands.ts"],"names":[],"mappings":"AAEA,MAAM,MAAM,eAAe,GAAG,CAAC,GAAG,MAAM,EAAE,MAAM,EAAE,KAAK,IAAI,CAAC;AAE5D,qBAAa,cAAc;aAMT,EAAE,EAAE,MAAM;aACV,IAAI,EAAE,MAAM;IAL7B,SAAgB,QAAQ,uBAA8B;IAC/C,IAAI,UAAQ;gBAGF,EAAE,EAAE,MAAM,EACV,IAAI,EAAE,MAAM;IAG7B,UAAU,CAAC,OAAO,EAAE,OAAO;CAI3B;AAED,qBAAa,OAAO;IAEnB,SAAgB,EAAE,EAAE,MAAM,CAAC;IAC3B,SAAgB,IAAI,EAAE,MAAM,CAAC;IAC7B,SAAgB,KAAK,EAAE,MAAM,CAAC;IAC9B,SAAgB,OAAO,EAAE,MAAM,CAAC;IAChC,SAAgB,EAAE,EAAE,eAAe,CAAC;IACpC,SAAgB,cAAc,EAAE,MAAM,CAAC;gBAE3B,OAAO,EAAE,OAAO,CAAC,OAAO,CAAC;IAMrC,IAAI,CAAC,GAAG,MAAM,EAAE,MAAM,EAAE;CAIxB;AAED,qBAAa,QAAQ;IAEpB,SAAgB,QAAQ,8BAAqC;IAE7D,IAAI,KAAK,WAIR;gBAEW,QAAQ,CAAC,EAAE,OAAO,CAAC,OAAO,CAAC,EAAE;IAIzC,KAAK;IAKL,eAAe,CAAC,OAAO,EAAE,OAAO,CAAC,cAAc,CAAC,EAAE,MAAM,UAAO;IAO/D,aAAa,CAAC,SAAS,EAAE,MAAM;IAI/B,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC,OAAO,CAAC;IAMlC,MAAM,CAAC,IAAI,EAAE,MAAM;IAInB,GAAG,CAAC,IAAI,EAAE,MAAM;IAOhB,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,MAAM,EAAE;IAIzC,MAAM,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,eAAe,UAAQ,EAAE,aAAa,UAAQ,GAAG,CAAC,cAAc,GAAC,OAAO,CAAC,EAAE;IA0BjG,KAAK,CAAC,QAAQ,EAAE,QAAQ,GAAG,QAAQ;CAOnC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"commands.js","sourceRoot":"","sources":["../../src/model/commands.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAIxC,MAAM,OAAO,cAAc;IAK1B,YACiB,EAAU,EACV,IAAY;QADZ,OAAE,GAAF,EAAE,CAAQ;QACV,SAAI,GAAJ,IAAI,CAAQ;QALb,aAAQ,GAAG,IAAI,GAAG,EAAmB,CAAC;QAC/C,SAAI,GAAG,IAAI,CAAC;IAKf,CAAC;IAEL,UAAU,CAAC,OAAgB;QAC1B,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;IACxC,CAAC;CAED;AAED,MAAM,OAAO,OAAO;
|
|
1
|
+
{"version":3,"file":"commands.js","sourceRoot":"","sources":["../../src/model/commands.ts"],"names":[],"mappings":"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","sourcesContent":["import { utils } from \"@omegagrid/core\";\n\nexport type CommandFunction = (...params: string[]) => void;\n\nexport class CommandSection {\n\n\tpublic readonly commands = new Map<string, Command>();\n\tpublic open = true;\n\n\tconstructor(\n\t\tpublic readonly id: string,\n\t\tpublic readonly name: string\n\t) { }\n\n\taddCommand(command: Command) {\n\t\tthis.commands.set(command.id, command);\n\t}\n\n}\n\nexport class Command {\n\n\tpublic readonly id: string;\n\tpublic readonly name: string;\n\tpublic readonly value: string;\n\tpublic readonly section: string;\n\tpublic readonly fn: CommandFunction;\n\tpublic readonly requiredParams: number;\n\n\tconstructor(options: Partial<Command>) {\n\t\tObject.assign(this, options);\n\t\tthis.id = options.id || options.name;\n\t\tthis.name = options.name || options.id;\n\t}\n\n\texec(...params: string[]) {\n\t\tif (this.fn) this.fn(...params);\n\t}\n\n}\n\nexport class Commands {\n\t\n\tpublic readonly sections = new Map<string, CommandSection>();\n\n\tget count() {\n\t\tlet cnt = 0;\n\t\tthis.sections.forEach(section => cnt += section.commands.size);\n\t\treturn cnt;\n\t}\n\n\tconstructor(commands?: Partial<Command>[]) {\n\t\tif (commands) commands.forEach(c => this.register(c));\n\t}\n\n\tclear() {\n\t\tthis.sections.clear();\n\t\treturn this;\n\t}\n\n\tregisterSection(section: Partial<CommandSection>, append = true) {\n\t\tconst s = append && this.sections.has(section.id) ? this.sections.get(section.id) : new CommandSection(section.id, section.name);\n\t\tsection.commands?.forEach(c => s.commands.set(c.id, c));\n\t\tthis.sections.set(s.id, s);\n\t\treturn s;\n\t}\n\n\tremoveSection(sectionId: string) {\n\t\tthis.sections.delete(sectionId);\n\t}\n\t\n\tregister(command: Partial<Command>) {\n\t\tconst sectionId = command.section || 'default';\n\t\tconst section = this.sections.get(sectionId) || this.registerSection({id: sectionId, name: sectionId});\n\t\tsection.addCommand(new Command(command));\n\t}\n\n\tremove(name: string) {\n\t\tthis.sections.forEach(section => section.commands.delete(name));\n\t}\n\n\tget(name: string) {\n\t\tfor (const section of this.sections.values()) {\n\t\t\tif (section.commands.has(name)) return section.commands.get(name);\n\t\t}\n\t\treturn null;\n\t}\n\n\texec(command: string, ...params: string[]) {\n\t\tthis.get(command)?.exec(...params);\n\t}\n\n\tfilter(term?: string, includeSections = false, emptySections = false): (CommandSection|Command)[] {\n\t\tconst items: (CommandSection|Command)[] = [];\n\t\tconst regex = term == null ? null : new RegExp(utils.escapeRegExp(term), 'ig');\n\t\tfor (const section of this.sections.values()) {\n\t\t\tlet sectionIcluded = false;\n\t\t\tconst sectionMatch = regex ? regex.test(section.name) : true;\n\t\t\tif (sectionMatch && emptySections) {\n\t\t\t\titems.push(section);\n\t\t\t\tsectionIcluded = true;\n\t\t\t}\n\n\t\t\tif (section.open) {\n\t\t\t\tsection.commands.forEach(command => {\n\t\t\t\t\tif (sectionMatch || regex.test(command.name)) {\n\t\t\t\t\t\tif (includeSections && !sectionIcluded) {\n\t\t\t\t\t\t\titems.push(section);\n\t\t\t\t\t\t\tsectionIcluded = true;\n\t\t\t\t\t\t}\n\t\t\t\t\t\titems.push(command);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t\treturn items;\n\t}\n\n\tmerge(commands: Commands): Commands {\n\t\tconst mergedCommands = new Commands();\n\t\tthis.sections.forEach(s => mergedCommands.registerSection(s));\n\t\tcommands.sections.forEach(s => mergedCommands.registerSection(s));\n\t\treturn mergedCommands;\n\t}\n\n}"]}
|
|
@@ -4,7 +4,8 @@ import { LitElement, TemplateResult, PropertyValues } from 'lit';
|
|
|
4
4
|
import { Options } from "../model";
|
|
5
5
|
export declare class CommandEvent extends Event {
|
|
6
6
|
readonly command?: Command;
|
|
7
|
-
|
|
7
|
+
readonly value?: string;
|
|
8
|
+
constructor(type: string, args?: Partial<CommandEvent>);
|
|
8
9
|
}
|
|
9
10
|
export type CommandRenderer = (div: HTMLDivElement, command: Command) => string | TemplateResult<1> | null;
|
|
10
11
|
export type SectionRenderer = (div: HTMLDivElement, section: CommandSection) => string | TemplateResult<1> | null;
|
|
@@ -12,15 +13,24 @@ export declare class CommandWindow extends LitElement {
|
|
|
12
13
|
static styles: import("lit").CSSResult[];
|
|
13
14
|
private inputRef;
|
|
14
15
|
get input(): HTMLInputElement;
|
|
16
|
+
get inputValue(): string;
|
|
15
17
|
private listRef;
|
|
16
18
|
get list(): List;
|
|
17
19
|
private visibleItems;
|
|
18
20
|
options: Options;
|
|
21
|
+
/**
|
|
22
|
+
* search = commands are filtered by input value
|
|
23
|
+
* input = commands are not filtered, input is used to enter custom value
|
|
24
|
+
* none = no input, only command list is shown
|
|
25
|
+
*/
|
|
26
|
+
mode: 'search' | 'input' | 'none';
|
|
27
|
+
value: string;
|
|
19
28
|
text: string;
|
|
20
29
|
commands: Commands;
|
|
21
30
|
adapter: CommandsAdapter;
|
|
22
31
|
target: HTMLElement;
|
|
23
32
|
triggerKey: string;
|
|
33
|
+
placeholder: string;
|
|
24
34
|
showSections: boolean;
|
|
25
35
|
requireUpdateCommands: boolean;
|
|
26
36
|
_commandRenderer: CommandRenderer;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"commandWindow.d.ts","sourceRoot":"","sources":["../../src/ui/commandWindow.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAC9E,OAAO,EAAO,IAAI,EAAE,gBAAgB,EAAE,eAAe,EAAqB,MAAM,iBAAiB,CAAC;AAClG,OAAO,EAAE,UAAU,EAAQ,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAMvE,OAAO,EAAE,OAAO,EAAE,MAAM,UAAU,CAAC;AAEnC,qBAAa,YAAa,SAAQ,KAAK;
|
|
1
|
+
{"version":3,"file":"commandWindow.d.ts","sourceRoot":"","sources":["../../src/ui/commandWindow.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAC9E,OAAO,EAAO,IAAI,EAAE,gBAAgB,EAAE,eAAe,EAAqB,MAAM,iBAAiB,CAAC;AAClG,OAAO,EAAE,UAAU,EAAQ,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAMvE,OAAO,EAAE,OAAO,EAAE,MAAM,UAAU,CAAC;AAEnC,qBAAa,YAAa,SAAQ,KAAK;IAEtC,QAAQ,CAAC,OAAO,CAAC,EAAE,OAAO,CAAC;IAC3B,QAAQ,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC;gBAEZ,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,CAAC,YAAY,CAAC;CAItD;AAED,MAAM,MAAM,eAAe,GAAG,CAAC,GAAG,EAAE,cAAc,EAAE,OAAO,EAAE,OAAO,KAAK,MAAM,GAAG,cAAc,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;AAC3G,MAAM,MAAM,eAAe,GAAG,CAAC,GAAG,EAAE,cAAc,EAAE,OAAO,EAAE,cAAc,KAAK,MAAM,GAAG,cAAc,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;AAElH,qBACa,aAAc,SAAQ,UAAU;IAE5C,MAAM,CAAC,MAAM,4BAAW;IAExB,OAAO,CAAC,QAAQ,CAAiC;IACjD,IAAI,KAAK,qBAAkC;IAC3C,IAAI,UAAU,WAAqC;IAEnD,OAAO,CAAC,OAAO,CAAqB;IACpC,IAAI,IAAI,SAAkC;IAE1C,OAAO,CAAC,YAAY,CAA6B;IAGjD,OAAO,EAAE,OAAO,CAAC;IAEjB;;;;OAIG;IAEH,IAAI,EAAE,QAAQ,GAAG,OAAO,GAAG,MAAM,CAAY;IAG7C,KAAK,EAAE,MAAM,CAAC;IAGd,IAAI,EAAE,MAAM,CAAC;IAGb,QAAQ,WAAkB;IAG1B,OAAO,EAAE,eAAe,CAAC;IAGzB,MAAM,EAAE,WAAW,CAAC;IAGpB,UAAU,SAAQ;IAGlB,WAAW,SAAM;IAGjB,YAAY,UAAQ;IAEpB,qBAAqB,UAAQ;IAE7B,gBAAgB,EAAE,eAAe,CAM/B;IAEF,gBAAgB,EAAE,eAAe,CAW/B;IAEF,IAAI,WAAW,WAA6D;IAE5E,IAAI,CAAC,aAAa,UAAO;IAoCzB,UAAU,MAAO,aAAa,UAuB7B;IAED,QAAQ;;uBAlJR,CAAA;MA2JE;;IAUI,IAAI,CAAC,aAAa,UAAO;IAkB/B,KAAK,CAAC,aAAa,UAAO;IAQ1B,iBAAiB;IAKjB,gBAAgB,MAAO,aAAa,UAMnC;IAEK,UAAU,CAAC,KAAK,EAAE,cAAc;IAYhC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,WAAW,EAAE,OAAO,CAAC;IAW9C,SAAS,MAAO,eAAe,UAa9B;IAED,aAAa,EAAE,gBAAgB,CAI9B;IAED,YAAY;IAKN,cAAc;IAgBd,aAAa,CAAC,SAAS,EAAE,MAAM;IAsBrC,cAAc;IAUd,MAAM,0BAmBJ;CAEF"}
|
package/dist/ui/commandWindow.js
CHANGED
|
@@ -13,15 +13,17 @@ import { debounce } from "ts-debounce";
|
|
|
13
13
|
import { style, itemStyle } from "./commandWindow.style";
|
|
14
14
|
import constants from "../constants";
|
|
15
15
|
export class CommandEvent extends Event {
|
|
16
|
-
constructor(type,
|
|
16
|
+
constructor(type, args) {
|
|
17
17
|
super(`command.${type}`, { bubbles: true, composed: true });
|
|
18
|
-
|
|
18
|
+
if (args)
|
|
19
|
+
Object.assign(this, args);
|
|
19
20
|
}
|
|
20
21
|
}
|
|
21
22
|
let CommandWindow = class CommandWindow extends LitElement {
|
|
22
23
|
get input() { return this.inputRef?.value; }
|
|
24
|
+
get inputValue() { return this.input?.value ?? ''; }
|
|
23
25
|
get list() { return this.listRef?.value; }
|
|
24
|
-
get filterValue() { return this.input.value; }
|
|
26
|
+
get filterValue() { return this.mode == 'search' ? this.input.value : null; }
|
|
25
27
|
exec(dispatchEvent = true) {
|
|
26
28
|
const tokens = this.input.value.split('>').map(t => t.trim());
|
|
27
29
|
if (tokens[0].length == 0) {
|
|
@@ -29,9 +31,11 @@ let CommandWindow = class CommandWindow extends LitElement {
|
|
|
29
31
|
tokens[0] = this.visibleItems[this.list.selectedIndex].name;
|
|
30
32
|
}
|
|
31
33
|
}
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
34
|
+
if (this.mode == 'search') {
|
|
35
|
+
const command = this.commands.get(tokens[0])
|
|
36
|
+
?? this.visibleItems.find(item => item instanceof Command && item.name == tokens[0]);
|
|
37
|
+
if (!command)
|
|
38
|
+
return;
|
|
35
39
|
if (tokens.length - 1 < command.requiredParams) {
|
|
36
40
|
tokens.push('');
|
|
37
41
|
this.input.value = tokens.join(' > ');
|
|
@@ -41,17 +45,38 @@ let CommandWindow = class CommandWindow extends LitElement {
|
|
|
41
45
|
tokens.shift();
|
|
42
46
|
command.exec(...tokens);
|
|
43
47
|
if (dispatchEvent)
|
|
44
|
-
this.dispatchEvent(new CommandEvent('exec',
|
|
48
|
+
this.dispatchEvent(new CommandEvent('exec', {
|
|
49
|
+
command,
|
|
50
|
+
value: this.inputValue
|
|
51
|
+
}));
|
|
45
52
|
this.close();
|
|
46
53
|
}
|
|
47
54
|
}
|
|
55
|
+
else {
|
|
56
|
+
const command = this.visibleItems[this.list.selectedIndex];
|
|
57
|
+
if (!command)
|
|
58
|
+
return;
|
|
59
|
+
if (dispatchEvent)
|
|
60
|
+
this.dispatchEvent(new CommandEvent('exec', {
|
|
61
|
+
command: command,
|
|
62
|
+
value: this.inputValue
|
|
63
|
+
}));
|
|
64
|
+
this.close();
|
|
65
|
+
}
|
|
48
66
|
}
|
|
49
67
|
constructor() {
|
|
50
68
|
super();
|
|
51
69
|
this.inputRef = createRef();
|
|
52
70
|
this.listRef = createRef();
|
|
71
|
+
/**
|
|
72
|
+
* search = commands are filtered by input value
|
|
73
|
+
* input = commands are not filtered, input is used to enter custom value
|
|
74
|
+
* none = no input, only command list is shown
|
|
75
|
+
*/
|
|
76
|
+
this.mode = 'search';
|
|
53
77
|
this.commands = new Commands();
|
|
54
78
|
this.triggerKey = 'F1';
|
|
79
|
+
this.placeholder = '';
|
|
55
80
|
this.showSections = false;
|
|
56
81
|
this.requireUpdateCommands = true;
|
|
57
82
|
this._commandRenderer = (div, command) => {
|
|
@@ -100,10 +125,12 @@ let CommandWindow = class CommandWindow extends LitElement {
|
|
|
100
125
|
};
|
|
101
126
|
this._onKeyUp = debounce(e => {
|
|
102
127
|
e.stopPropagation();
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
128
|
+
if (this.mode == 'search') {
|
|
129
|
+
const excludedKeys = ['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight', 'Shift', 'Enter', this.triggerKey];
|
|
130
|
+
if (excludedKeys.indexOf(e.key) == -1) {
|
|
131
|
+
this.updateCommands();
|
|
132
|
+
this.list.size = this.visibleItems.length;
|
|
133
|
+
}
|
|
107
134
|
}
|
|
108
135
|
});
|
|
109
136
|
this._onTargetKeyDown = (e) => {
|
|
@@ -116,10 +143,10 @@ let CommandWindow = class CommandWindow extends LitElement {
|
|
|
116
143
|
this._onSelect = (e) => {
|
|
117
144
|
const item = this.visibleItems[e.index];
|
|
118
145
|
if (item instanceof Command) {
|
|
119
|
-
this.
|
|
120
|
-
|
|
146
|
+
if (this.mode == 'search')
|
|
147
|
+
this.input.value = item.name;
|
|
148
|
+
if (e.trigger == ListSelectTrigger.Click || e.trigger == ListSelectTrigger.Enter)
|
|
121
149
|
this.exec();
|
|
122
|
-
}
|
|
123
150
|
}
|
|
124
151
|
else {
|
|
125
152
|
this.input.value = '';
|
|
@@ -136,9 +163,14 @@ let CommandWindow = class CommandWindow extends LitElement {
|
|
|
136
163
|
};
|
|
137
164
|
this.render = () => html `
|
|
138
165
|
<div class="input">
|
|
139
|
-
<input
|
|
166
|
+
<input ${ref(this.inputRef)}
|
|
167
|
+
type="text"
|
|
168
|
+
.placeholder="${this.placeholder}"
|
|
169
|
+
.value="${this.value}">
|
|
140
170
|
</div>
|
|
171
|
+
|
|
141
172
|
${this.text != null ? html `<div class="text">${this.text}</div>` : ''}
|
|
173
|
+
|
|
142
174
|
<div class="list">
|
|
143
175
|
<og-list ${ref(this.listRef)}
|
|
144
176
|
maxHeight="300"
|
|
@@ -158,7 +190,7 @@ let CommandWindow = class CommandWindow extends LitElement {
|
|
|
158
190
|
if (!this.target)
|
|
159
191
|
throw new Error('target element not set');
|
|
160
192
|
dom.showElement(this);
|
|
161
|
-
this.input.value = '';
|
|
193
|
+
this.input.value = this.value ?? '';
|
|
162
194
|
if (this.requireUpdateCommands) {
|
|
163
195
|
this.requireUpdateCommands = false;
|
|
164
196
|
await this.updateCommands();
|
|
@@ -264,6 +296,12 @@ CommandWindow.styles = [style];
|
|
|
264
296
|
__decorate([
|
|
265
297
|
property({ type: Object })
|
|
266
298
|
], CommandWindow.prototype, "options", void 0);
|
|
299
|
+
__decorate([
|
|
300
|
+
property({ type: String })
|
|
301
|
+
], CommandWindow.prototype, "mode", void 0);
|
|
302
|
+
__decorate([
|
|
303
|
+
property({ type: String })
|
|
304
|
+
], CommandWindow.prototype, "value", void 0);
|
|
267
305
|
__decorate([
|
|
268
306
|
property({ type: String })
|
|
269
307
|
], CommandWindow.prototype, "text", void 0);
|
|
@@ -279,6 +317,9 @@ __decorate([
|
|
|
279
317
|
__decorate([
|
|
280
318
|
property({ type: String })
|
|
281
319
|
], CommandWindow.prototype, "triggerKey", void 0);
|
|
320
|
+
__decorate([
|
|
321
|
+
property({ type: String })
|
|
322
|
+
], CommandWindow.prototype, "placeholder", void 0);
|
|
282
323
|
__decorate([
|
|
283
324
|
property({ type: Boolean })
|
|
284
325
|
], CommandWindow.prototype, "showSections", void 0);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"commandWindow.js","sourceRoot":"","sources":["../../src/ui/commandWindow.ts"],"names":[],"mappings":"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","sourcesContent":["import { Commands, Command, CommandsAdapter, CommandSection } from \"../model\";\nimport { dom, List, ListItemRenderer, ListSelectEvent, ListSelectTrigger } from \"@omegagrid/core\";\nimport { LitElement, html, TemplateResult, PropertyValues } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { createRef, ref } from 'lit/directives/ref.js';\nimport { debounce } from \"ts-debounce\";\nimport { style, itemStyle } from \"./commandWindow.style\";\nimport constants from \"../constants\";\nimport { Options } from \"../model\";\n\nexport class CommandEvent extends Event {\n\tconstructor(type: string, public readonly command?: Command) {\n\t\tsuper(`command.${type}`, {bubbles: true, composed: true})\n\t}\n}\n\nexport type CommandRenderer = (div: HTMLDivElement, command: Command) => string | TemplateResult<1> | null;\nexport type SectionRenderer = (div: HTMLDivElement, section: CommandSection) => string | TemplateResult<1> | null;\n\n@customElement('og-commands')\nexport class CommandWindow extends LitElement {\n\n\tstatic styles = [style];\n\n\tprivate inputRef = createRef<HTMLInputElement>();\n\tget input() { return this.inputRef?.value; }\n\n\tprivate listRef = createRef<List>();\n\tget list() { return this.listRef?.value; }\n\n\tprivate visibleItems: (Command|CommandSection)[];\n\n\t@property({type: Object})\n\toptions: Options;\n\n\t@property({type: String})\n\ttext: string\n\n\t@property({type: Object})\n\tcommands = new Commands();\n\t\n\t@property({type: Object})\n\tadapter: CommandsAdapter;\n\n\t@property({type: Object})\n\ttarget: HTMLElement;\n\n\t@property({type: String})\n\ttriggerKey = 'F1';\n\t\n\t@property({type: Boolean})\n\tshowSections = false\n\n\trequireUpdateCommands = true;\n\n\t_commandRenderer: CommandRenderer = (div: HTMLDivElement, command: Command) => {\n\t\treturn html`\n\t\t\t<div class=\"command\">\n\t\t\t\t${command.name}\n\t\t\t</div>\n\t\t`;\n\t};\n\n\t_sectionRenderer: SectionRenderer = (div: HTMLDivElement, section: CommandSection) => {\n\t\treturn html`\n\t\t\t<div class=\"section\" @mousedown=\"${(e: MouseEvent) => e.preventDefault()}\">\n\t\t\t\t<div class=\"section-toggle\">\n\t\t\t\t\t<og-fa-icon icon=\"angle-${section.open ? 'down' : 'right'}\"></og-fa-icon>\n\t\t\t\t</div>\n\t\t\t\t<div class=\"section-text\">\n\t\t\t\t\t${section.name}\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t`;\n\t};\n\n\tget filterValue() { return this.input.value }\n\n\texec(dispatchEvent = true) {\n\t\tconst tokens = this.input.value.split('>').map(t => t.trim());\n\t\tif (tokens[0].length == 0) {\n\t\t\tif (this.list.selectedIndex > -1 && this.list.selectedIndex < this.visibleItems.length) {\n\t\t\t\ttokens[0] = this.visibleItems[this.list.selectedIndex].name;\n\t\t\t}\n\t\t}\n\n\t\tconst command = this.commands.get(tokens[0])\n\t\t\t?? this.visibleItems.find(item => item instanceof Command && item.name == tokens[0]) as Command;\n\t\t\n\t\tif (command) {\n\t\t\tif (tokens.length - 1 < command.requiredParams) {\n\t\t\t\ttokens.push('');\n\t\t\t\tthis.input.value = tokens.join(' > ');\n\t\t\t\tthis.input.focus();\n\t\t\t} else {\n\t\t\t\ttokens.shift();\n\t\t\t\tcommand.exec(...tokens);\n\t\t\t\tif (dispatchEvent) this.dispatchEvent(new CommandEvent('exec', command));\n\t\t\t\tthis.close();\n\t\t\t}\n\t\t}\n\t}\n\n\t_onKeyDown = (e: KeyboardEvent) => {\n\t\te.stopPropagation();\n\t\tswitch (e.key) {\n\t\t\tcase 'ArrowDown':\n\t\t\t\te.preventDefault();\n\t\t\t\tthis.list.moveDown();\n\t\t\t\tbreak;\n\t\t\tcase 'ArrowUp':\n\t\t\t\te.preventDefault();\n\t\t\t\tthis.list.moveUp();\n\t\t\t\tbreak;\n\t\t\tcase 'Enter':\n\t\t\t\te.preventDefault();\n\t\t\t\tif (this.visibleItems[this.list.selectedIndex] instanceof CommandSection) \n\t\t\t\t\tthis.toggleSection((this.visibleItems[this.list.selectedIndex] as CommandSection).id);\n\t\t\t\telse this.exec();\n\t\t\t\tbreak;\n\t\t\tcase 'Escape':\n\t\t\tcase this.triggerKey:\n\t\t\t\te.preventDefault();\n\t\t\t\tthis.close();\n\t\t\t\tbreak;\n\t\t}\n\t}\n\n\t_onKeyUp = debounce(e => {\n\t\te.stopPropagation();\n\t\tconst excludedKeys = ['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight', 'Shift', 'Enter', this.triggerKey];\n\t\tif (excludedKeys.indexOf(e.key) == -1) {\n\t\t\tthis.updateCommands();\n\t\t\tthis.list.size = this.visibleItems.length;\n\t\t}\n\t})\n\n\tconstructor() {\n\t\tsuper();\n\t\tthis.addEventListener('click', e => e.stopPropagation());\n\t\tthis.addEventListener('keyup', this._onKeyUp);\n\t\tthis.addEventListener('keydown', this._onKeyDown);\n\t\tthis.addEventListener('blur', () => this.close());\n\t}\n\n\tasync open(dispatchEvent = true) {\n\t\tif (!this.target) throw new Error('target element not set');\n\n\t\tdom.showElement(this);\n\t\tthis.input.value = '';\n\t\t\n\t\tif (this.requireUpdateCommands) {\n\t\t\tthis.requireUpdateCommands = false; \n\t\t\tawait this.updateCommands();\n\t\t}\n\t\t\n\t\tthis.input.focus();\n\t\tthis.visibleItems = this.commands.filter(null, this.showSections);\n\t\tthis.updatePosition();\n\t\t\n\t\tif (dispatchEvent) this.dispatchEvent(new CommandEvent('open'));\n\t}\n\n\tclose(dispatchEvent = true) {\n\t\tif (this.target) {\n\t\t\tdom.hideElement(this);\n\t\t\tthis.target.focus();\n\t\t\tif (dispatchEvent) this.dispatchEvent(new CommandEvent('close'));\n\t\t}\n\t}\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback();\n\t\tthis.tabIndex = 0;\n\t}\n\n\t_onTargetKeyDown = (e: KeyboardEvent) => {\n\t\tif (e.key == this.triggerKey) {\n\t\t\te.stopPropagation();\n\t\t\te.preventDefault();\n\t\t\tthis.open();\n\t\t}\n\t}\n\n\tasync willUpdate(props: PropertyValues) {\n\t\tif (props.has('adapter') && this.adapter) {\n\t\t\tconst options = await this.adapter.getOptions();\n\t\t\tif (options) this.options = options;\n\t\t}\n\n\t\tif (this.options) {\n\t\t\tif (this.options.commandRenderer) this._commandRenderer = this.options.commandRenderer;\n\t\t\tif (this.options.sectionRenderer) this._sectionRenderer = this.options.sectionRenderer;\n\t\t}\n\t}\n\n\tasync updated(props: Map<PropertyKey, unknown>) {\n\t\tif (props.has('target')) {\n\t\t\tconst oldTarget = props.get('target') as HTMLElement;\n\t\t\tif (oldTarget) oldTarget.removeEventListener('keydown', this._onTargetKeyDown);\n\t\t\tif (this.target) this.target.addEventListener('keydown', this._onTargetKeyDown);\n\t\t}\n\t\tif (props.has('adapter')) this.requireUpdateCommands = true;\n\t\tif (props.has('commands')) await this.updateCommands();\n\t\tthis.updatePosition();\n\t}\n\n\t_onSelect = (e: ListSelectEvent) => {\n\t\tconst item = this.visibleItems[e.index];\n\t\tif (item instanceof Command) {\n\t\t\tthis.input.value = item.name;\n\t\t\tif (e.trigger == ListSelectTrigger.Click || e.trigger == ListSelectTrigger.Enter) {\n\t\t\t\tthis.exec();\n\t\t\t}\n\t\t} else {\n\t\t\tthis.input.value = '';\n\t\t\tif (e.trigger == ListSelectTrigger.Click || e.trigger == ListSelectTrigger.Enter) {\n\t\t\t\tthis.toggleSection((item as CommandSection).id);\n\t\t\t}\n\t\t}\n\n\t\tsetTimeout(() => this.input.focus());\n\t}\n\n\t_itemRenderer: ListItemRenderer = (div: HTMLDivElement, index: number) => {\n\t\treturn this.visibleItems[index] instanceof CommandSection\n\t\t\t? this._sectionRenderer(div, this.visibleItems[index] as CommandSection)\n\t\t\t: this._commandRenderer(div, this.visibleItems[index] as Command);\n\t}\n\n\tfirstUpdated() {\n\t\tthis.list.itemRenderer = this._itemRenderer;\n\t\tthis.list.addEventListener('select', this._onSelect);\n\t}\n\n\tasync updateCommands() {\n\t\tif (this.adapter) {\n\t\t\tthis.commands.clear();\n\t\t\tconst sections = (await Promise.all([this.adapter.getSections(this.filterValue)]))[0];\n\t\t\tsections.forEach(section => this.commands.registerSection(section, false));\n\t\t\tthis.visibleItems = this.commands.filter(null, this.showSections, true);\n\t\t} else {\n\t\t\tthis.visibleItems = this.commands.filter(this.filterValue, this.showSections);\n\t\t}\n\n\t\tthis.list.size = this.visibleItems.length;\n\t\tthis.list.selectedIndex = this.list.size > 0 ? 0 : -1;\n\t\tthis.list.renderItems(true);\n\t\tawait this.list.updateComplete;\n\t}\n\n\tasync toggleSection(sectionId: string) {\n\t\tconst section = this.commands.sections.get(sectionId);\n\t\tif (section.open) {\n\t\t\tsection.open = false;\n\t\t\tthis.visibleItems = this.commands.filter(this.filterValue, this.showSections, true);\n\t\t\tthis.list.size = this.visibleItems.length;\n\t\t} else {\n\t\t\tsection.open = true;\n\t\t\tif (this.adapter) {\n\t\t\t\tconst commands = (await Promise.all([this.adapter.getCommands(sectionId, this.filterValue)]))[0];\n\t\t\t\tif (commands.length > 0) {\n\t\t\t\t\tsection.commands.clear();\n\t\t\t\t\tcommands.forEach(c => section.addCommand(c));\n\t\t\t\t}\n\t\t\t\tthis.visibleItems = this.commands.filter(null, this.showSections, true);\n\t\t\t} else {\n\t\t\t\tthis.visibleItems = this.commands.filter(this.filterValue, this.showSections, true);\n\t\t\t}\n\t\t}\n\t\tthis.list.size = this.visibleItems.length;\n\t}\n\n\tupdatePosition() {\n\t\tif (this.target) {\n\t\t\tdom.setSize(this, {\n\t\t\t\tw: Math.min(constants.COMMAND_WINDOW_MAX_WIDTH, 0.9 * this.target.clientWidth)\n\t\t\t});\n\t\t\tdom.setCenterPosition(this, this.target, {horizontal: true, vertical: false});\n\t\t\tdom.setPosition(this, {t: 100});\n\t\t}\n\t}\n\n\trender = () => html`\n\t\t<div class=\"input\">\n\t\t\t<input type=\"text\" ${ref(this.inputRef)}>\n\t\t</div>\n\t\t${this.text != null ? html`<div class=\"text\">${this.text}</div>` : ''}\n\t\t<div class=\"list\">\n\t\t\t<og-list ${ref(this.listRef)}\n\t\t\t\tmaxHeight=\"300\"\n\t\t\t\t.customStyle=\"${itemStyle}\"\n\t\t\t\titemHeight=\"22\"\n\t\t\t\tlineHeight=\"20\"\n\t\t\t\tarrowEvents>\n\t\t\t</og-list>\n\t\t</div>\n\t`;\n\n}"]}
|
|
1
|
+
{"version":3,"file":"commandWindow.js","sourceRoot":"","sources":["../../src/ui/commandWindow.ts"],"names":[],"mappings":"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","sourcesContent":["import { Commands, Command, CommandsAdapter, CommandSection } from \"../model\";\nimport { dom, List, ListItemRenderer, ListSelectEvent, ListSelectTrigger } from \"@omegagrid/core\";\nimport { LitElement, html, TemplateResult, PropertyValues } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { createRef, ref } from 'lit/directives/ref.js';\nimport { debounce } from \"ts-debounce\";\nimport { style, itemStyle } from \"./commandWindow.style\";\nimport constants from \"../constants\";\nimport { Options } from \"../model\";\n\nexport class CommandEvent extends Event {\n\n\treadonly command?: Command;\n\treadonly value?: string;\n\n\tconstructor(type: string, args?: Partial<CommandEvent>) {\n\t\tsuper(`command.${type}`, {bubbles: true, composed: true})\n\t\tif (args) Object.assign(this, args);\n\t}\n}\n\nexport type CommandRenderer = (div: HTMLDivElement, command: Command) => string | TemplateResult<1> | null;\nexport type SectionRenderer = (div: HTMLDivElement, section: CommandSection) => string | TemplateResult<1> | null;\n\n@customElement('og-commands')\nexport class CommandWindow extends LitElement {\n\n\tstatic styles = [style];\n\n\tprivate inputRef = createRef<HTMLInputElement>();\n\tget input() { return this.inputRef?.value }\n\tget inputValue() { return this.input?.value ?? '' }\n\n\tprivate listRef = createRef<List>();\n\tget list() { return this.listRef?.value; }\n\n\tprivate visibleItems: (Command|CommandSection)[];\n\n\t@property({type: Object})\n\toptions: Options;\n\n\t/**\n\t * search = commands are filtered by input value\n\t * input = commands are not filtered, input is used to enter custom value\n\t * none = no input, only command list is shown\n\t */\n\t@property({type: String})\n\tmode: 'search' | 'input' | 'none' = 'search';\n\n\t@property({type: String})\n\tvalue: string;\n\n\t@property({type: String})\n\ttext: string;\n\n\t@property({type: Object})\n\tcommands = new Commands();\n\t\n\t@property({type: Object})\n\tadapter: CommandsAdapter;\n\n\t@property({type: Object})\n\ttarget: HTMLElement;\n\n\t@property({type: String})\n\ttriggerKey = 'F1';\n\n\t@property({type: String})\n\tplaceholder = '';\n\t\n\t@property({type: Boolean})\n\tshowSections = false\n\n\trequireUpdateCommands = true;\n\n\t_commandRenderer: CommandRenderer = (div: HTMLDivElement, command: Command) => {\n\t\treturn html`\n\t\t\t<div class=\"command\">\n\t\t\t\t${command.name}\n\t\t\t</div>\n\t\t`;\n\t};\n\n\t_sectionRenderer: SectionRenderer = (div: HTMLDivElement, section: CommandSection) => {\n\t\treturn html`\n\t\t\t<div class=\"section\" @mousedown=\"${(e: MouseEvent) => e.preventDefault()}\">\n\t\t\t\t<div class=\"section-toggle\">\n\t\t\t\t\t<og-fa-icon icon=\"angle-${section.open ? 'down' : 'right'}\"></og-fa-icon>\n\t\t\t\t</div>\n\t\t\t\t<div class=\"section-text\">\n\t\t\t\t\t${section.name}\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t`;\n\t};\n\n\tget filterValue() { return this.mode == 'search' ? this.input.value : null }\n\n\texec(dispatchEvent = true) {\n\t\tconst tokens = this.input.value.split('>').map(t => t.trim());\n\t\tif (tokens[0].length == 0) {\n\t\t\tif (this.list.selectedIndex > -1 && this.list.selectedIndex < this.visibleItems.length) {\n\t\t\t\ttokens[0] = this.visibleItems[this.list.selectedIndex].name;\n\t\t\t}\n\t\t}\n\n\t\tif (this.mode == 'search') {\n\t\t\tconst command = this.commands.get(tokens[0])\n\t\t\t\t?? this.visibleItems.find(item => item instanceof Command && item.name == tokens[0]) as Command;\n\t\t\tif (!command) return;\n\t\t\tif (tokens.length - 1 < command.requiredParams) {\n\t\t\t\ttokens.push('');\n\t\t\t\tthis.input.value = tokens.join(' > ');\n\t\t\t\tthis.input.focus();\n\t\t\t} else {\n\t\t\t\ttokens.shift();\n\t\t\t\tcommand.exec(...tokens);\n\t\t\t\tif (dispatchEvent) this.dispatchEvent(new CommandEvent('exec', { \n\t\t\t\t\tcommand, \n\t\t\t\t\tvalue: this.inputValue\n\t\t\t\t}));\n\t\t\t\tthis.close();\n\t\t\t}\n\t\t} else {\n\t\t\tconst command = this.visibleItems[this.list.selectedIndex] as Command;\n\t\t\tif (!command) return;\n\t\t\tif (dispatchEvent) this.dispatchEvent(new CommandEvent('exec', { \n\t\t\t\tcommand: command,\n\t\t\t\tvalue: this.inputValue\n\t\t\t}));\n\t\t\tthis.close();\n\t\t}\n\t}\n\n\t_onKeyDown = (e: KeyboardEvent) => {\n\t\te.stopPropagation();\n\t\tswitch (e.key) {\n\t\t\tcase 'ArrowDown':\n\t\t\t\te.preventDefault();\n\t\t\t\tthis.list.moveDown();\n\t\t\t\tbreak;\n\t\t\tcase 'ArrowUp':\n\t\t\t\te.preventDefault();\n\t\t\t\tthis.list.moveUp();\n\t\t\t\tbreak;\n\t\t\tcase 'Enter':\n\t\t\t\te.preventDefault();\n\t\t\t\tif (this.visibleItems[this.list.selectedIndex] instanceof CommandSection) \n\t\t\t\t\tthis.toggleSection((this.visibleItems[this.list.selectedIndex] as CommandSection).id);\n\t\t\t\telse this.exec();\n\t\t\t\tbreak;\n\t\t\tcase 'Escape':\n\t\t\tcase this.triggerKey:\n\t\t\t\te.preventDefault();\n\t\t\t\tthis.close();\n\t\t\t\tbreak;\n\t\t}\n\t}\n\n\t_onKeyUp = debounce(e => {\n\t\te.stopPropagation();\n\t\tif (this.mode == 'search') {\n\t\t\tconst excludedKeys = ['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight', 'Shift', 'Enter', this.triggerKey];\n\t\t\tif (excludedKeys.indexOf(e.key) == -1) {\n\t\t\t\tthis.updateCommands();\n\t\t\t\tthis.list.size = this.visibleItems.length;\n\t\t\t}\n\t\t}\n\t})\n\n\tconstructor() {\n\t\tsuper();\n\t\tthis.addEventListener('click', e => e.stopPropagation());\n\t\tthis.addEventListener('keyup', this._onKeyUp);\n\t\tthis.addEventListener('keydown', this._onKeyDown);\n\t\tthis.addEventListener('blur', () => this.close());\n\t}\n\n\tasync open(dispatchEvent = true) {\n\t\tif (!this.target) throw new Error('target element not set');\n\n\t\tdom.showElement(this);\n\t\tthis.input.value = this.value ?? '';\n\t\t\n\t\tif (this.requireUpdateCommands) {\n\t\t\tthis.requireUpdateCommands = false;\n\t\t\tawait this.updateCommands();\n\t\t}\n\t\t\n\t\tthis.input.focus();\n\t\tthis.visibleItems = this.commands.filter(null, this.showSections);\n\t\tthis.updatePosition();\n\t\t\n\t\tif (dispatchEvent) this.dispatchEvent(new CommandEvent('open'));\n\t}\n\n\tclose(dispatchEvent = true) {\n\t\tif (this.target) {\n\t\t\tdom.hideElement(this);\n\t\t\tthis.target.focus();\n\t\t\tif (dispatchEvent) this.dispatchEvent(new CommandEvent('close'));\n\t\t}\n\t}\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback();\n\t\tthis.tabIndex = 0;\n\t}\n\n\t_onTargetKeyDown = (e: KeyboardEvent) => {\n\t\tif (e.key == this.triggerKey) {\n\t\t\te.stopPropagation();\n\t\t\te.preventDefault();\n\t\t\tthis.open();\n\t\t}\n\t}\n\n\tasync willUpdate(props: PropertyValues) {\n\t\tif (props.has('adapter') && this.adapter) {\n\t\t\tconst options = await this.adapter.getOptions();\n\t\t\tif (options) this.options = options;\n\t\t}\n\n\t\tif (this.options) {\n\t\t\tif (this.options.commandRenderer) this._commandRenderer = this.options.commandRenderer;\n\t\t\tif (this.options.sectionRenderer) this._sectionRenderer = this.options.sectionRenderer;\n\t\t}\n\t}\n\n\tasync updated(props: Map<PropertyKey, unknown>) {\n\t\tif (props.has('target')) {\n\t\t\tconst oldTarget = props.get('target') as HTMLElement;\n\t\t\tif (oldTarget) oldTarget.removeEventListener('keydown', this._onTargetKeyDown);\n\t\t\tif (this.target) this.target.addEventListener('keydown', this._onTargetKeyDown);\n\t\t}\n\t\tif (props.has('adapter')) this.requireUpdateCommands = true;\n\t\tif (props.has('commands')) await this.updateCommands();\n\t\tthis.updatePosition();\n\t}\n\n\t_onSelect = (e: ListSelectEvent) => {\n\t\tconst item = this.visibleItems[e.index];\n\t\tif (item instanceof Command) {\n\t\t\tif (this.mode == 'search') this.input.value = item.name;\t\t\t\n\t\t\tif (e.trigger == ListSelectTrigger.Click || e.trigger == ListSelectTrigger.Enter) this.exec();\n\t\t} else {\n\t\t\tthis.input.value = '';\n\t\t\tif (e.trigger == ListSelectTrigger.Click || e.trigger == ListSelectTrigger.Enter) {\n\t\t\t\tthis.toggleSection((item as CommandSection).id);\n\t\t\t}\n\t\t}\n\n\t\tsetTimeout(() => this.input.focus());\n\t}\n\n\t_itemRenderer: ListItemRenderer = (div: HTMLDivElement, index: number) => {\n\t\treturn this.visibleItems[index] instanceof CommandSection\n\t\t\t? this._sectionRenderer(div, this.visibleItems[index] as CommandSection)\n\t\t\t: this._commandRenderer(div, this.visibleItems[index] as Command);\n\t}\n\n\tfirstUpdated() {\n\t\tthis.list.itemRenderer = this._itemRenderer;\n\t\tthis.list.addEventListener('select', this._onSelect);\n\t}\n\n\tasync updateCommands() {\n\t\tif (this.adapter) {\n\t\t\tthis.commands.clear();\n\t\t\tconst sections = (await Promise.all([this.adapter.getSections(this.filterValue)]))[0];\n\t\t\tsections.forEach(section => this.commands.registerSection(section, false));\n\t\t\tthis.visibleItems = this.commands.filter(null, this.showSections, true);\n\t\t} else {\n\t\t\tthis.visibleItems = this.commands.filter(this.filterValue, this.showSections);\n\t\t}\n\n\t\tthis.list.size = this.visibleItems.length;\n\t\tthis.list.selectedIndex = this.list.size > 0 ? 0 : -1;\n\t\tthis.list.renderItems(true);\n\t\tawait this.list.updateComplete;\n\t}\n\n\tasync toggleSection(sectionId: string) {\n\t\tconst section = this.commands.sections.get(sectionId);\n\t\tif (section.open) {\n\t\t\tsection.open = false;\n\t\t\tthis.visibleItems = this.commands.filter(this.filterValue, this.showSections, true);\n\t\t\tthis.list.size = this.visibleItems.length;\n\t\t} else {\n\t\t\tsection.open = true;\n\t\t\tif (this.adapter) {\n\t\t\t\tconst commands = (await Promise.all([this.adapter.getCommands(sectionId, this.filterValue)]))[0];\n\t\t\t\tif (commands.length > 0) {\n\t\t\t\t\tsection.commands.clear();\n\t\t\t\t\tcommands.forEach(c => section.addCommand(c));\n\t\t\t\t}\n\t\t\t\tthis.visibleItems = this.commands.filter(null, this.showSections, true);\n\t\t\t} else {\n\t\t\t\tthis.visibleItems = this.commands.filter(this.filterValue, this.showSections, true);\n\t\t\t}\n\t\t}\n\t\tthis.list.size = this.visibleItems.length;\n\t}\n\n\tupdatePosition() {\n\t\tif (this.target) {\n\t\t\tdom.setSize(this, {\n\t\t\t\tw: Math.min(constants.COMMAND_WINDOW_MAX_WIDTH, 0.9 * this.target.clientWidth)\n\t\t\t});\n\t\t\tdom.setCenterPosition(this, this.target, {horizontal: true, vertical: false});\n\t\t\tdom.setPosition(this, {t: 100});\n\t\t}\n\t}\n\n\trender = () => html`\n\t\t<div class=\"input\">\n\t\t\t<input ${ref(this.inputRef)}\n\t\t\t\ttype=\"text\"\n\t\t\t\t.placeholder=\"${this.placeholder}\"\n\t\t\t\t.value=\"${this.value}\">\n\t\t</div>\n\n\t\t${this.text != null ? html`<div class=\"text\">${this.text}</div>` : ''}\n\t\t\n\t\t<div class=\"list\">\n\t\t\t<og-list ${ref(this.listRef)}\n\t\t\t\tmaxHeight=\"300\"\n\t\t\t\t.customStyle=\"${itemStyle}\"\n\t\t\t\titemHeight=\"22\"\n\t\t\t\tlineHeight=\"20\"\n\t\t\t\tarrowEvents>\n\t\t\t</og-list>\n\t\t</div>\n\t`;\n\n}"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@omegagrid/commands",
|
|
3
|
-
"version": "0.6.
|
|
3
|
+
"version": "0.6.118",
|
|
4
4
|
"license": "UNLICENSED",
|
|
5
5
|
"description": "Command window",
|
|
6
6
|
"main": "./dist/index.js",
|
|
@@ -27,7 +27,7 @@
|
|
|
27
27
|
"_prepublish": "yarn test && yarn lint"
|
|
28
28
|
},
|
|
29
29
|
"dependencies": {
|
|
30
|
-
"@omegagrid/core": "^0.6.
|
|
30
|
+
"@omegagrid/core": "^0.6.118",
|
|
31
31
|
"lit": "^3.1.1",
|
|
32
32
|
"lit-html": "^3.1.1",
|
|
33
33
|
"ts-debounce": "^4.0.0"
|