rust-analyzer/editors/code/src/commands/watch_status.ts

64 lines
1.6 KiB
TypeScript
Raw Normal View History

2019-03-31 12:51:17 +00:00
import * as vscode from 'vscode';
const spinnerFrames = ['⠋', '⠙', '⠹', '⠸', '⠼', '⠴', '⠦', '⠧', '⠇', '⠏'];
2019-04-13 20:13:21 +00:00
export class StatusDisplay implements vscode.Disposable {
public packageName?: string;
2019-03-31 12:51:17 +00:00
private i = 0;
private statusBarItem: vscode.StatusBarItem;
2019-06-24 10:02:20 +00:00
private command: string;
2019-03-31 12:51:17 +00:00
private timer?: NodeJS.Timeout;
2019-06-24 10:02:20 +00:00
constructor(command: string) {
2019-03-31 13:21:14 +00:00
this.statusBarItem = vscode.window.createStatusBarItem(
vscode.StatusBarAlignment.Left,
10
);
2019-06-24 10:02:20 +00:00
this.command = command;
2019-03-31 12:51:17 +00:00
this.statusBarItem.hide();
}
public show() {
this.packageName = undefined;
2019-03-31 13:21:14 +00:00
this.timer =
this.timer ||
setInterval(() => {
if (this.packageName) {
2019-06-24 10:02:20 +00:00
this.statusBarItem!.text = `cargo ${this.command} [${
this.packageName
}] ${this.frame()}`;
} else {
2019-06-24 10:50:34 +00:00
this.statusBarItem!.text = `cargo ${
this.command
} ${this.frame()}`;
}
2019-03-31 13:21:14 +00:00
}, 300);
2019-03-31 12:51:17 +00:00
2019-04-13 20:13:21 +00:00
this.statusBarItem.show();
2019-03-31 12:51:17 +00:00
}
public hide() {
if (this.timer) {
clearInterval(this.timer);
this.timer = undefined;
}
2019-04-13 20:13:21 +00:00
this.statusBarItem.hide();
}
public dispose() {
if (this.timer) {
clearInterval(this.timer);
this.timer = undefined;
}
this.statusBarItem.dispose();
2019-03-31 12:51:17 +00:00
}
private frame() {
2019-03-31 13:21:14 +00:00
return spinnerFrames[(this.i = ++this.i % spinnerFrames.length)];
2019-03-31 12:51:17 +00:00
}
2019-03-31 13:21:14 +00:00
}