mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-03-30 16:50:30 -04:00
137 lines
4.7 KiB
TypeScript
137 lines
4.7 KiB
TypeScript
/*---------------------------------------------------------------------------------------------
|
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
|
*--------------------------------------------------------------------------------------------*/
|
|
|
|
import 'vs/css!./quickInput';
|
|
import * as dom from 'vs/base/browser/dom';
|
|
import { InputBox, IRange, MessageType } from 'vs/base/browser/ui/inputbox/inputBox';
|
|
import { inputBackground, inputForeground, inputBorder, inputValidationInfoBackground, inputValidationInfoForeground, inputValidationInfoBorder, inputValidationWarningBackground, inputValidationWarningForeground, inputValidationWarningBorder, inputValidationErrorBackground, inputValidationErrorForeground, inputValidationErrorBorder } from 'vs/platform/theme/common/colorRegistry';
|
|
import { ITheme } from 'vs/platform/theme/common/themeService';
|
|
import { dispose, IDisposable } from 'vs/base/common/lifecycle';
|
|
import { StandardKeyboardEvent } from 'vs/base/browser/keyboardEvent';
|
|
import Severity from 'vs/base/common/severity';
|
|
import { StandardMouseEvent } from 'vs/base/browser/mouseEvent';
|
|
|
|
const $ = dom.$;
|
|
|
|
export class QuickInputBox {
|
|
|
|
private container: HTMLElement;
|
|
private inputBox: InputBox;
|
|
private disposables: IDisposable[] = [];
|
|
|
|
constructor(
|
|
private parent: HTMLElement
|
|
) {
|
|
this.container = dom.append(this.parent, $('.quick-input-box'));
|
|
this.inputBox = new InputBox(this.container, undefined);
|
|
this.disposables.push(this.inputBox);
|
|
}
|
|
|
|
onKeyDown = (handler: (event: StandardKeyboardEvent) => void): IDisposable => {
|
|
return dom.addDisposableListener(this.inputBox.inputElement, dom.EventType.KEY_DOWN, (e: KeyboardEvent) => {
|
|
handler(new StandardKeyboardEvent(e));
|
|
});
|
|
}
|
|
|
|
onMouseDown = (handler: (event: StandardMouseEvent) => void): IDisposable => {
|
|
return dom.addDisposableListener(this.inputBox.inputElement, dom.EventType.MOUSE_DOWN, (e: MouseEvent) => {
|
|
handler(new StandardMouseEvent(e));
|
|
});
|
|
}
|
|
|
|
onDidChange = (handler: (event: string) => void): IDisposable => {
|
|
return this.inputBox.onDidChange(handler);
|
|
}
|
|
|
|
get value() {
|
|
return this.inputBox.value;
|
|
}
|
|
|
|
set value(value: string) {
|
|
this.inputBox.value = value;
|
|
}
|
|
|
|
select(range: IRange | null = null): void {
|
|
this.inputBox.select(range);
|
|
}
|
|
|
|
setPlaceholder(placeholder: string) {
|
|
this.inputBox.setPlaceHolder(placeholder);
|
|
}
|
|
|
|
get placeholder() {
|
|
return this.inputBox.inputElement.getAttribute('placeholder') || '';
|
|
}
|
|
|
|
set placeholder(placeholder: string) {
|
|
this.inputBox.setPlaceHolder(placeholder);
|
|
}
|
|
|
|
get password() {
|
|
return this.inputBox.inputElement.type === 'password';
|
|
}
|
|
|
|
set password(password: boolean) {
|
|
this.inputBox.inputElement.type = password ? 'password' : 'text';
|
|
}
|
|
|
|
set enabled(enabled: boolean) {
|
|
this.inputBox.setEnabled(enabled);
|
|
}
|
|
|
|
hasFocus(): boolean {
|
|
return this.inputBox.hasFocus();
|
|
}
|
|
|
|
setAttribute(name: string, value: string) {
|
|
this.inputBox.inputElement.setAttribute(name, value);
|
|
}
|
|
|
|
removeAttribute(name: string) {
|
|
this.inputBox.inputElement.removeAttribute(name);
|
|
}
|
|
|
|
showDecoration(decoration: Severity): void {
|
|
if (decoration === Severity.Ignore) {
|
|
this.inputBox.hideMessage();
|
|
} else {
|
|
this.inputBox.showMessage({ type: decoration === Severity.Info ? MessageType.INFO : decoration === Severity.Warning ? MessageType.WARNING : MessageType.ERROR, content: '' });
|
|
}
|
|
}
|
|
|
|
stylesForType(decoration: Severity) {
|
|
return this.inputBox.stylesForType(decoration === Severity.Info ? MessageType.INFO : decoration === Severity.Warning ? MessageType.WARNING : MessageType.ERROR);
|
|
}
|
|
|
|
setFocus(): void {
|
|
this.inputBox.focus();
|
|
}
|
|
|
|
layout(): void {
|
|
this.inputBox.layout();
|
|
}
|
|
|
|
style(theme: ITheme) {
|
|
this.inputBox.style({
|
|
inputForeground: theme.getColor(inputForeground),
|
|
inputBackground: theme.getColor(inputBackground),
|
|
inputBorder: theme.getColor(inputBorder),
|
|
inputValidationInfoBackground: theme.getColor(inputValidationInfoBackground),
|
|
inputValidationInfoForeground: theme.getColor(inputValidationInfoForeground),
|
|
inputValidationInfoBorder: theme.getColor(inputValidationInfoBorder),
|
|
inputValidationWarningBackground: theme.getColor(inputValidationWarningBackground),
|
|
inputValidationWarningForeground: theme.getColor(inputValidationWarningForeground),
|
|
inputValidationWarningBorder: theme.getColor(inputValidationWarningBorder),
|
|
inputValidationErrorBackground: theme.getColor(inputValidationErrorBackground),
|
|
inputValidationErrorForeground: theme.getColor(inputValidationErrorForeground),
|
|
inputValidationErrorBorder: theme.getColor(inputValidationErrorBorder),
|
|
});
|
|
}
|
|
|
|
dispose() {
|
|
this.disposables = dispose(this.disposables);
|
|
}
|
|
}
|