Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
cad45237
V
vscode
项目概览
掘金者说
/
vscode
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
V
vscode
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
cad45237
编写于
3月 26, 2018
作者:
C
Christof Marti
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Subscribe to cancellation token (#45589)
上级
addd944e
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
25 addition
and
20 deletion
+25
-20
src/vs/workbench/browser/parts/quickinput/quickInput.ts
src/vs/workbench/browser/parts/quickinput/quickInput.ts
+25
-20
未找到文件。
src/vs/workbench/browser/parts/quickinput/quickInput.ts
浏览文件 @
cad45237
...
...
@@ -46,7 +46,7 @@ export class QuickInputService extends Component implements IQuickInputService {
private
checkboxList
:
QuickInputCheckboxList
;
private
ignoreFocusLost
=
false
;
private
resolve
:
(
value
?:
object
[]
|
Thenable
<
object
[]
>
)
=>
void
;
private
resolve
:
(
value
?:
IPickOpenEntry
[]
|
Thenable
<
IPickOpenEntry
[]
>
)
=>
void
;
constructor
(
@
IEnvironmentService
private
environmentService
:
IEnvironmentService
,
...
...
@@ -99,7 +99,7 @@ export class QuickInputService extends Component implements IQuickInputService {
const
ok
=
dom
.
append
(
headerContainer
,
$
(
'
button.quick-input-action
'
));
ok
.
textContent
=
localize
(
'
ok
'
,
"
OK
"
);
this
.
toUnbind
.
push
(
dom
.
addDisposableListener
(
ok
,
dom
.
EventType
.
CLICK
,
e
=>
this
.
close
(
t
rue
)));
this
.
toUnbind
.
push
(
dom
.
addDisposableListener
(
ok
,
dom
.
EventType
.
CLICK
,
e
=>
this
.
close
(
t
his
.
checkboxList
.
getSelectedElements
()
)));
this
.
checkboxList
=
this
.
instantiationService
.
createInstance
(
QuickInputCheckboxList
,
this
.
container
);
this
.
toUnbind
.
push
(
this
.
checkboxList
);
...
...
@@ -123,7 +123,7 @@ export class QuickInputService extends Component implements IQuickInputService {
}
}
if
(
!
this
.
ignoreFocusLost
&&
!
this
.
environmentService
.
args
[
'
sticky-quickopen
'
]
&&
this
.
configurationService
.
getValue
(
CLOSE_ON_FOCUS_LOST_CONFIG
))
{
this
.
close
(
false
);
this
.
close
();
}
}));
this
.
toUnbind
.
push
(
dom
.
addDisposableListener
(
this
.
container
,
dom
.
EventType
.
KEY_DOWN
,
(
e
:
KeyboardEvent
)
=>
{
...
...
@@ -131,54 +131,59 @@ export class QuickInputService extends Component implements IQuickInputService {
switch
(
event
.
keyCode
)
{
case
KeyCode
.
Enter
:
dom
.
EventHelper
.
stop
(
e
,
true
);
this
.
close
(
t
rue
);
this
.
close
(
t
his
.
checkboxList
.
getSelectedElements
()
);
break
;
case
KeyCode
.
Escape
:
dom
.
EventHelper
.
stop
(
e
,
true
);
this
.
close
(
false
);
this
.
close
();
break
;
}
}));
this
.
toUnbind
.
push
(
this
.
quickOpenService
.
onShow
(()
=>
this
.
close
(
false
)));
this
.
toUnbind
.
push
(
this
.
quickOpenService
.
onShow
(()
=>
this
.
close
()));
}
private
close
(
ok
:
boolean
)
{
private
close
(
value
?:
IPickOpenEntry
[]
|
Thenable
<
IPickOpenEntry
[]
>
)
{
if
(
this
.
resolve
)
{
if
(
ok
)
{
this
.
resolve
(
this
.
checkboxList
.
getSelectedElements
());
}
else
{
this
.
resolve
();
}
this
.
resolve
(
value
);
}
this
.
container
.
style
.
display
=
'
none
'
;
}
async
pick
<
T
extends
IPickOpenEntry
>
(
picks
:
TPromise
<
T
[]
>
,
options
:
IPickOptions
=
{},
token
?:
CancellationToken
):
TPromise
<
T
[]
>
{
pick
<
T
extends
IPickOpenEntry
>
(
picks
:
TPromise
<
T
[]
>
,
options
:
IPickOptions
=
{},
token
:
CancellationToken
=
CancellationToken
.
None
):
TPromise
<
T
[]
>
{
this
.
create
();
this
.
quickOpenService
.
close
();
if
(
this
.
resolve
)
{
this
.
resolve
();
}
// TODO: Listen on cancellation token.
this
.
inputBox
.
setValue
(
''
);
// TODO: Localize shortcut.
this
.
inputBox
.
setPlaceholder
(
options
.
placeHolder
||
''
);
// TODO: Progress indication.
this
.
checkboxList
.
setElements
(
await
picks
);
this
.
checkboxList
.
matchOnDescription
=
options
.
matchOnDescription
;
this
.
checkboxList
.
matchOnDetail
=
options
.
matchOnDetail
;
this
.
ignoreFocusLost
=
options
.
ignoreFocusLost
;
this
.
checkboxList
.
setElements
([]);
this
.
selectAll
.
checked
=
this
.
checkboxList
.
getAllVisibleSelected
();
this
.
count
.
setCount
(
this
.
checkboxList
.
getSelectedCount
());
this
.
ignoreFocusLost
=
options
.
ignoreFocusLost
;
this
.
container
.
style
.
display
=
null
;
this
.
updateLayout
();
this
.
inputBox
.
setFocus
();
return
new
TPromise
<
T
[]
>
(
resolve
=>
this
.
resolve
=
resolve
);
const
result
=
new
TPromise
<
T
[]
>
(
resolve
=>
this
.
resolve
=
resolve
);
const
d
=
token
.
onCancellationRequested
(()
=>
this
.
close
());
result
.
then
(()
=>
d
.
dispose
(),
()
=>
d
.
dispose
());
// TODO: Progress indication.
picks
.
then
(
elements
=>
{
this
.
checkboxList
.
setElements
(
elements
);
this
.
selectAll
.
checked
=
this
.
checkboxList
.
getAllVisibleSelected
();
this
.
count
.
setCount
(
this
.
checkboxList
.
getSelectedCount
());
this
.
updateLayout
();
}).
then
(
null
,
reason
=>
this
.
close
(
TPromise
.
wrapError
(
reason
)));
return
result
;
}
public
layout
(
dimension
:
Dimension
):
void
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录