Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
01344d13
V
vscode
项目概览
xxadev
/
vscode
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
V
vscode
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
01344d13
编写于
5月 22, 2017
作者:
A
Alex Dima
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fixes #27088
上级
28c5b1f6
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
25 addition
and
5 deletion
+25
-5
src/vs/workbench/parts/preferences/browser/keybindingWidgets.ts
.../workbench/parts/preferences/browser/keybindingWidgets.ts
+25
-5
未找到文件。
src/vs/workbench/parts/preferences/browser/keybindingWidgets.ts
浏览文件 @
01344d13
...
...
@@ -27,11 +27,12 @@ import { editorWidgetBackground, widgetShadow } from "vs/platform/theme/common/c
class
KeybindingInputWidget
extends
Widget
{
p
ublic
readonly
inputBox
:
InputBox
;
p
rivate
readonly
inputBox
:
InputBox
;
private
_acceptChords
:
boolean
;
private
_firstPart
:
ResolvedKeybinding
;
private
_chordPart
:
ResolvedKeybinding
;
private
_inputValue
:
string
;
private
_onKeybinding
=
this
.
_register
(
new
Emitter
<
[
ResolvedKeybinding
,
ResolvedKeybinding
]
>
());
public
readonly
onKeybinding
:
Event
<
[
ResolvedKeybinding
,
ResolvedKeybinding
]
>
=
this
.
_onKeybinding
.
event
;
...
...
@@ -42,6 +43,9 @@ class KeybindingInputWidget extends Widget {
private
_onEscape
=
this
.
_register
(
new
Emitter
<
void
>
());
public
readonly
onEscape
:
Event
<
void
>
=
this
.
_onEscape
.
event
;
private
_onBlur
=
this
.
_register
(
new
Emitter
<
void
>
());
public
readonly
onBlur
:
Event
<
void
>
=
this
.
_onBlur
.
event
;
constructor
(
parent
:
HTMLElement
,
private
options
:
IInputOptions
,
@
IContextViewService
private
contextViewService
:
IContextViewService
,
@
IKeybindingService
private
keybindingService
:
IKeybindingService
,
...
...
@@ -51,11 +55,27 @@ class KeybindingInputWidget extends Widget {
this
.
inputBox
=
this
.
_register
(
new
InputBox
(
parent
,
this
.
contextViewService
,
this
.
options
));
this
.
_register
(
attachInputBoxStyler
(
this
.
inputBox
,
themeService
));
this
.
onkeydown
(
this
.
inputBox
.
inputElement
,
e
=>
this
.
_onKeyDown
(
e
));
this
.
onblur
(
this
.
inputBox
.
inputElement
,
(
e
)
=>
this
.
_onBlur
.
fire
());
this
.
oninput
(
this
.
inputBox
.
inputElement
,
(
e
)
=>
{
// Prevent other characters from showing up
this
.
setInputValue
(
this
.
_inputValue
);
});
this
.
_acceptChords
=
true
;
this
.
_firstPart
=
null
;
this
.
_chordPart
=
null
;
}
public
setInputValue
(
value
:
string
):
void
{
this
.
_inputValue
=
value
;
this
.
inputBox
.
value
=
this
.
_inputValue
;
}
public
focus
():
void
{
this
.
inputBox
.
focus
();
}
public
reset
()
{
this
.
_firstPart
=
null
;
this
.
_chordPart
=
null
;
...
...
@@ -107,7 +127,7 @@ class KeybindingInputWidget extends Widget {
if
(
this
.
_chordPart
)
{
value
=
value
+
'
'
+
this
.
_chordPart
.
getUserSettingsLabel
();
}
this
.
inputBox
.
value
=
value
;
this
.
setInputValue
(
value
)
;
this
.
inputBox
.
inputElement
.
title
=
info
;
this
.
_onKeybinding
.
fire
([
this
.
_firstPart
,
this
.
_chordPart
]);
...
...
@@ -155,9 +175,9 @@ export class DefineKeybindingWidget extends Widget {
this
.
_firstPart
=
null
;
this
.
_chordPart
=
null
;
this
.
_keybindingInputWidget
.
inputBox
.
value
=
''
;
this
.
_keybindingInputWidget
.
setInputValue
(
''
)
;
dom
.
clearNode
(
this
.
_outputNode
);
this
.
_keybindingInputWidget
.
inputBox
.
focus
();
this
.
_keybindingInputWidget
.
focus
();
}
const
disposable
=
this
.
_onHide
.
event
(()
=>
{
if
(
this
.
_firstPart
)
{
...
...
@@ -204,7 +224,7 @@ export class DefineKeybindingWidget extends Widget {
this
.
_register
(
this
.
_keybindingInputWidget
.
onKeybinding
(
keybinding
=>
this
.
printKeybinding
(
keybinding
)));
this
.
_register
(
this
.
_keybindingInputWidget
.
onEnter
(()
=>
this
.
hide
()));
this
.
_register
(
this
.
_keybindingInputWidget
.
onEscape
(()
=>
this
.
onCancel
()));
this
.
_register
(
dom
.
addDisposableListener
(
this
.
_keybindingInputWidget
.
inputBox
.
inputElement
,
'
blur
'
,
e
=>
this
.
onCancel
()));
this
.
_register
(
this
.
_keybindingInputWidget
.
onBlur
(()
=>
this
.
onCancel
()));
this
.
_outputNode
=
dom
.
append
(
this
.
_domNode
.
domNode
,
dom
.
$
(
'
.output
'
));
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录