Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
7cae7a0b
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,发现更多精彩内容 >>
提交
7cae7a0b
编写于
7月 22, 2020
作者:
J
João Moreno
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
submenu support on toolbars :partying_face:
上级
de26a534
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
32 addition
and
9 deletion
+32
-9
src/vs/base/browser/ui/toolbar/toolbar.ts
src/vs/base/browser/ui/toolbar/toolbar.ts
+32
-9
未找到文件。
src/vs/base/browser/ui/toolbar/toolbar.ts
浏览文件 @
7cae7a0b
...
...
@@ -5,10 +5,10 @@
import
'
vs/css!./toolbar
'
;
import
*
as
nls
from
'
vs/nls
'
;
import
{
Action
,
IActionRunner
,
IAction
,
IActionViewItemProvider
}
from
'
vs/base/common/actions
'
;
import
{
Action
,
IActionRunner
,
IAction
,
IActionViewItemProvider
,
SubmenuAction
}
from
'
vs/base/common/actions
'
;
import
{
ActionBar
,
ActionsOrientation
}
from
'
vs/base/browser/ui/actionbar/actionbar
'
;
import
{
ResolvedKeybinding
}
from
'
vs/base/common/keyCodes
'
;
import
{
Disposable
,
IDisposabl
e
}
from
'
vs/base/common/lifecycle
'
;
import
{
Disposable
,
DisposableStor
e
}
from
'
vs/base/common/lifecycle
'
;
import
{
AnchorAlignment
}
from
'
vs/base/browser/ui/contextview/contextview
'
;
import
{
withNullAsUndefined
}
from
'
vs/base/common/types
'
;
import
{
Codicon
,
registerIcon
}
from
'
vs/base/common/codicons
'
;
...
...
@@ -38,12 +38,13 @@ export class ToolBar extends Disposable {
private
actionBar
:
ActionBar
;
private
toggleMenuAction
:
ToggleMenuAction
;
private
toggleMenuActionViewItem
:
DropdownMenuActionViewItem
|
undefined
;
private
submenuActionViewItems
:
DropdownMenuActionViewItem
[]
=
[];
private
hasSecondaryActions
:
boolean
=
false
;
private
lookupKeybindings
:
boolean
;
private
_onDidChangeDropdownVisibility
=
this
.
_register
(
new
EventMultiplexer
<
boolean
>
());
readonly
onDidChangeDropdownVisibility
=
this
.
_onDidChangeDropdownVisibility
.
event
;
private
d
ropdownMenuDisposables
=
new
Set
<
IDisposable
>
();
private
d
isposables
=
new
DisposableStore
();
constructor
(
container
:
HTMLElement
,
contextMenuProvider
:
IContextMenuProvider
,
options
:
IToolBarOptions
=
{
orientation
:
ActionsOrientation
.
HORIZONTAL
})
{
super
();
...
...
@@ -62,6 +63,28 @@ export class ToolBar extends Disposable {
ariaLabel
:
options
.
ariaLabel
,
actionRunner
:
options
.
actionRunner
,
actionViewItemProvider
:
(
action
:
IAction
)
=>
{
if
(
action
instanceof
SubmenuAction
)
{
const
actions
=
Array
.
isArray
(
action
.
actions
)
?
action
.
actions
:
action
.
actions
();
const
result
=
new
DropdownMenuActionViewItem
(
action
,
actions
,
contextMenuProvider
,
{
actionViewItemProvider
:
this
.
options
.
actionViewItemProvider
,
actionRunner
:
this
.
actionRunner
,
keybindingProvider
:
this
.
options
.
getKeyBinding
,
clazz
:
action
.
class
,
anchorAlignmentProvider
:
this
.
options
.
anchorAlignmentProvider
,
menuAsChild
:
true
}
);
result
.
setActionContext
(
this
.
actionBar
.
context
);
this
.
submenuActionViewItems
.
push
(
result
);
this
.
disposables
.
add
(
this
.
_onDidChangeDropdownVisibility
.
add
(
result
.
onDidChangeVisibility
));
return
result
;
}
if
(
action
.
id
===
ToggleMenuAction
.
ID
)
{
this
.
toggleMenuActionViewItem
=
new
DropdownMenuActionViewItem
(
action
,
...
...
@@ -77,7 +100,7 @@ export class ToolBar extends Disposable {
}
);
this
.
toggleMenuActionViewItem
.
setActionContext
(
this
.
actionBar
.
context
);
this
.
d
ropdownMenuD
isposables
.
add
(
this
.
_onDidChangeDropdownVisibility
.
add
(
this
.
toggleMenuActionViewItem
.
onDidChangeVisibility
));
this
.
disposables
.
add
(
this
.
_onDidChangeDropdownVisibility
.
add
(
this
.
toggleMenuActionViewItem
.
onDidChangeVisibility
));
return
this
.
toggleMenuActionViewItem
;
}
...
...
@@ -100,6 +123,9 @@ export class ToolBar extends Disposable {
if
(
this
.
toggleMenuActionViewItem
)
{
this
.
toggleMenuActionViewItem
.
setActionContext
(
context
);
}
for
(
const
actionViewItem
of
this
.
submenuActionViewItems
)
{
actionViewItem
.
setActionContext
(
context
);
}
}
getContainer
():
HTMLElement
{
...
...
@@ -142,11 +168,8 @@ export class ToolBar extends Disposable {
}
private
clear
():
void
{
for
(
const
disposable
of
this
.
dropdownMenuDisposables
)
{
disposable
.
dispose
();
}
this
.
dropdownMenuDisposables
.
clear
();
this
.
submenuActionViewItems
=
[];
this
.
disposables
.
clear
();
this
.
actionBar
.
clear
();
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录