Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
9b9030d5
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,发现更多精彩内容 >>
提交
9b9030d5
编写于
7月 06, 2017
作者:
S
Sandeep Somavarapu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix #30177
上级
bf410d4c
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
27 addition
and
18 deletion
+27
-18
src/vs/workbench/parts/preferences/browser/keybindingsEditor.ts
.../workbench/parts/preferences/browser/keybindingsEditor.ts
+8
-9
src/vs/workbench/parts/preferences/browser/preferences.contribution.ts
...nch/parts/preferences/browser/preferences.contribution.ts
+13
-2
src/vs/workbench/parts/preferences/browser/preferencesWidgets.ts
...workbench/parts/preferences/browser/preferencesWidgets.ts
+2
-6
src/vs/workbench/parts/preferences/common/preferences.ts
src/vs/workbench/parts/preferences/common/preferences.ts
+4
-1
未找到文件。
src/vs/workbench/parts/preferences/browser/keybindingsEditor.ts
浏览文件 @
9b9030d5
...
...
@@ -25,7 +25,7 @@ import { IKeybindingService, IUserFriendlyKeybinding } from 'vs/platform/keybind
import
{
SearchWidget
}
from
'
vs/workbench/parts/preferences/browser/preferencesWidgets
'
;
import
{
DefineKeybindingWidget
}
from
'
vs/workbench/parts/preferences/browser/keybindingWidgets
'
;
import
{
IPreferencesService
,
IKeybindingsEditor
,
CONTEXT_KEYBINDING_FOCUS
,
CONTEXT_KEYBINDINGS_EDITOR
,
KEYBINDINGS_EDITOR_COMMAND_REMOVE
,
KEYBINDINGS_EDITOR_COMMAND_COPY
,
IPreferencesService
,
IKeybindingsEditor
,
CONTEXT_KEYBINDING_FOCUS
,
CONTEXT_KEYBINDINGS_EDITOR
,
CONTEXT_KEYBINDINGS_SEARCH_FOCUS
,
KEYBINDINGS_EDITOR_COMMAND_REMOVE
,
KEYBINDINGS_EDITOR_COMMAND_COPY
,
KEYBINDINGS_EDITOR_COMMAND_RESET
,
KEYBINDINGS_EDITOR_COMMAND_DEFINE
,
KEYBINDINGS_EDITOR_COMMAND_SHOW_CONFLICTS
}
from
'
vs/workbench/parts/preferences/common/preferences
'
;
import
{
IContextMenuService
}
from
'
vs/platform/contextview/browser/contextView
'
;
...
...
@@ -94,6 +94,7 @@ export class KeybindingsEditor extends BaseEditor implements IKeybindingsEditor
private
delayedFilterLogging
:
Delayer
<
void
>
;
private
keybindingsEditorContextKey
:
IContextKey
<
boolean
>
;
private
keybindingFocusContextKey
:
IContextKey
<
boolean
>
;
private
searchFocusContextKey
:
IContextKey
<
boolean
>
;
private
sortByPrecedence
:
Checkbox
;
constructor
(
...
...
@@ -116,6 +117,7 @@ export class KeybindingsEditor extends BaseEditor implements IKeybindingsEditor
this
.
_register
(
keybindingsService
.
onDidUpdateKeybindings
(()
=>
this
.
render
()));
this
.
keybindingsEditorContextKey
=
CONTEXT_KEYBINDINGS_EDITOR
.
bindTo
(
this
.
contextKeyService
);
this
.
searchFocusContextKey
=
CONTEXT_KEYBINDINGS_SEARCH_FOCUS
.
bindTo
(
this
.
contextKeyService
);
this
.
keybindingFocusContextKey
=
CONTEXT_KEYBINDING_FOCUS
.
bindTo
(
this
.
contextKeyService
);
this
.
delayedFilterLogging
=
new
Delayer
<
void
>
(
1000
);
}
...
...
@@ -280,10 +282,9 @@ export class KeybindingsEditor extends BaseEditor implements IKeybindingsEditor
this
.
searchWidget
=
this
.
_register
(
this
.
instantiationService
.
createInstance
(
SearchWidget
,
searchContainer
,
{
ariaLabel
:
localize
(
'
SearchKeybindings.AriaLabel
'
,
"
Search keybindings
"
),
placeholder
:
localize
(
'
SearchKeybindings.Placeholder
'
,
"
Search keybindings
"
),
navigateByArrows
:
true
focusKey
:
this
.
searchFocusContextKey
}));
this
.
_register
(
this
.
searchWidget
.
onDidChange
(
searchValue
=>
this
.
delayedFiltering
.
trigger
(()
=>
this
.
filterKeybindings
())));
this
.
_register
(
this
.
searchWidget
.
onNavigate
(
back
=>
this
.
_onNavigate
(
back
)));
this
.
sortByPrecedence
=
this
.
_register
(
new
Checkbox
({
actionClassName
:
'
sort-by-precedence
'
,
...
...
@@ -426,12 +427,10 @@ export class KeybindingsEditor extends BaseEditor implements IKeybindingsEditor
}
}
private
_onNavigate
(
back
:
boolean
):
void
{
if
(
!
back
)
{
this
.
keybindingsList
.
getHTMLElement
().
focus
();
const
currentFocusIndices
=
this
.
keybindingsList
.
getFocus
();
this
.
keybindingsList
.
setFocus
([
currentFocusIndices
.
length
?
currentFocusIndices
[
0
]
:
0
]);
}
focusKeybindings
():
void
{
this
.
keybindingsList
.
getHTMLElement
().
focus
();
const
currentFocusIndices
=
this
.
keybindingsList
.
getFocus
();
this
.
keybindingsList
.
setFocus
([
currentFocusIndices
.
length
?
currentFocusIndices
[
0
]
:
0
]);
}
private
onContextMenu
(
e
:
IListContextMenuEvent
<
IListEntry
>
):
void
{
...
...
src/vs/workbench/parts/preferences/browser/preferences.contribution.ts
浏览文件 @
9b9030d5
...
...
@@ -19,8 +19,8 @@ import { DefaultPreferencesEditorInput, PreferencesEditor, PreferencesEditorInpu
import
{
KeybindingsEditor
,
KeybindingsEditorInput
}
from
'
vs/workbench/parts/preferences/browser/keybindingsEditor
'
;
import
{
OpenGlobalSettingsAction
,
OpenGlobalKeybindingsAction
,
OpenGlobalKeybindingsFileAction
,
OpenWorkspaceSettingsAction
,
ConfigureLanguageBasedSettingsAction
}
from
'
vs/workbench/parts/preferences/browser/preferencesActions
'
;
import
{
IPreferencesService
,
IKeybindingsEditor
,
CONTEXT_KEYBINDING_FOCUS
,
CONTEXT_KEYBINDINGS_EDITOR
,
KEYBINDINGS_EDITOR_COMMAND_DEFINE
,
KEYBINDINGS_EDITOR_COMMAND_REMOVE
,
KEYBINDINGS_EDITOR_COMMAND_SEARCH
,
KEYBINDINGS_EDITOR_COMMAND_COPY
,
KEYBINDINGS_EDITOR_COMMAND_RESET
,
KEYBINDINGS_EDITOR_COMMAND_SHOW_CONFLICTS
IPreferencesService
,
IKeybindingsEditor
,
CONTEXT_KEYBINDING_FOCUS
,
CONTEXT_KEYBINDINGS_EDITOR
,
CONTEXT_KEYBINDINGS_SEARCH_FOCUS
,
KEYBINDINGS_EDITOR_COMMAND_DEFINE
,
KEYBINDINGS_EDITOR_COMMAND_REMOVE
,
KEYBINDINGS_EDITOR_COMMAND_SEARCH
,
KEYBINDINGS_EDITOR_COMMAND_COPY
,
KEYBINDINGS_EDITOR_COMMAND_RESET
,
KEYBINDINGS_EDITOR_COMMAND_SHOW_CONFLICTS
,
KEYBINDINGS_EDITOR_COMMAND_FOCUS_KEYBINDINGS
}
from
'
vs/workbench/parts/preferences/common/preferences
'
;
import
{
PreferencesService
}
from
'
vs/workbench/parts/preferences/browser/preferencesService
'
;
import
{
IInstantiationService
}
from
'
vs/platform/instantiation/common/instantiation
'
;
...
...
@@ -234,4 +234,15 @@ KeybindingsRegistry.registerCommandAndKeybindingRule({
}
});
KeybindingsRegistry
.
registerCommandAndKeybindingRule
({
id
:
KEYBINDINGS_EDITOR_COMMAND_FOCUS_KEYBINDINGS
,
weight
:
KeybindingsRegistry
.
WEIGHT
.
workbenchContrib
(),
when
:
ContextKeyExpr
.
and
(
CONTEXT_KEYBINDINGS_EDITOR
,
CONTEXT_KEYBINDINGS_SEARCH_FOCUS
),
primary
:
KeyCode
.
DownArrow
,
handler
:
(
accessor
,
args
:
any
)
=>
{
const
editor
=
accessor
.
get
(
IWorkbenchEditorService
).
getActiveEditor
()
as
IKeybindingsEditor
;
editor
.
focusKeybindings
();
}
});
Registry
.
as
<
IWorkbenchContributionsRegistry
>
(
WorkbenchExtensions
.
Workbench
).
registerWorkbenchContribution
(
PreferencesContentProvider
);
\ No newline at end of file
src/vs/workbench/parts/preferences/browser/preferencesWidgets.ts
浏览文件 @
9b9030d5
...
...
@@ -288,8 +288,6 @@ export class SettingsTabsWidget extends Widget {
}
export
interface
SearchOptions
extends
IInputOptions
{
navigateByEnter
?:
boolean
;
navigateByArrows
?:
boolean
;
focusKey
?:
IContextKey
<
boolean
>
;
}
...
...
@@ -408,10 +406,8 @@ export class SearchWidget extends Widget {
let
handled
=
false
;
switch
(
keyboardEvent
.
keyCode
)
{
case
KeyCode
.
Enter
:
if
(
this
.
options
.
navigateByEnter
)
{
this
.
_onNavigate
.
fire
(
keyboardEvent
.
shiftKey
);
handled
=
true
;
}
this
.
_onNavigate
.
fire
(
keyboardEvent
.
shiftKey
);
handled
=
true
;
break
;
case
KeyCode
.
Escape
:
this
.
clear
();
...
...
src/vs/workbench/parts/preferences/common/preferences.ts
浏览文件 @
9b9030d5
...
...
@@ -86,6 +86,7 @@ export interface IKeybindingsEditor extends IEditor {
activeKeybindingEntry
:
IKeybindingItemEntry
;
search
(
filter
:
string
):
void
;
focusKeybindings
():
void
;
defineKeybinding
(
keybindingEntry
:
IKeybindingItemEntry
):
TPromise
<
any
>
;
removeKeybinding
(
keybindingEntry
:
IKeybindingItemEntry
):
TPromise
<
any
>
;
resetKeybinding
(
keybindingEntry
:
IKeybindingItemEntry
):
TPromise
<
any
>
;
...
...
@@ -96,6 +97,7 @@ export interface IKeybindingsEditor extends IEditor {
export
const
CONTEXT_SETTINGS_EDITOR
=
new
RawContextKey
<
boolean
>
(
'
inSettingsEditor
'
,
false
);
export
const
CONTEXT_SETTINGS_SEARCH_FOCUS
=
new
RawContextKey
<
boolean
>
(
'
inSettingsSearch
'
,
false
);
export
const
CONTEXT_KEYBINDINGS_EDITOR
=
new
RawContextKey
<
boolean
>
(
'
inKeybindings
'
,
false
);
export
const
CONTEXT_KEYBINDINGS_SEARCH_FOCUS
=
new
RawContextKey
<
boolean
>
(
'
inKeybindingsSearch
'
,
false
);
export
const
CONTEXT_KEYBINDING_FOCUS
=
new
RawContextKey
<
boolean
>
(
'
keybindingFocus
'
,
false
);
export
const
SETTINGS_EDITOR_COMMAND_SEARCH
=
'
settings.action.search
'
;
...
...
@@ -105,4 +107,5 @@ export const KEYBINDINGS_EDITOR_COMMAND_DEFINE = 'keybindings.editor.defineKeybi
export
const
KEYBINDINGS_EDITOR_COMMAND_REMOVE
=
'
keybindings.editor.removeKeybinding
'
;
export
const
KEYBINDINGS_EDITOR_COMMAND_RESET
=
'
keybindings.editor.resetKeybinding
'
;
export
const
KEYBINDINGS_EDITOR_COMMAND_COPY
=
'
keybindings.editor.copyKeybindingEntry
'
;
export
const
KEYBINDINGS_EDITOR_COMMAND_SHOW_CONFLICTS
=
'
keybindings.editor.showConflicts
'
;
\ No newline at end of file
export
const
KEYBINDINGS_EDITOR_COMMAND_SHOW_CONFLICTS
=
'
keybindings.editor.showConflicts
'
;
export
const
KEYBINDINGS_EDITOR_COMMAND_FOCUS_KEYBINDINGS
=
'
keybindings.editor.focusKeybindings
'
;
\ No newline at end of file
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录