Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
旅途_2012
vscode
提交
b44e7d9f
V
vscode
项目概览
旅途_2012
/
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,发现更多精彩内容 >>
未验证
提交
b44e7d9f
编写于
7月 09, 2018
作者:
S
SteVen Batten
提交者:
GitHub
7月 09, 2018
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fixes #52911 #53070 and aria roles with menuitem and submenuitems (#53289)
上级
1fc1292f
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
119 addition
and
25 deletion
+119
-25
src/vs/base/browser/ui/menu/menu.css
src/vs/base/browser/ui/menu/menu.css
+7
-0
src/vs/base/browser/ui/menu/menu.ts
src/vs/base/browser/ui/menu/menu.ts
+112
-25
未找到文件。
src/vs/base/browser/ui/menu/menu.css
浏览文件 @
b44e7d9f
...
...
@@ -39,6 +39,13 @@
background-color
:
#EEE
;
}
.monaco-menu
.monaco-action-bar.vertical
.action-menu-item
{
-ms-flex
:
1
1
auto
;
flex
:
1
1
auto
;
display
:
-ms-flexbox
;
display
:
flex
;
}
.monaco-menu
.monaco-action-bar.vertical
.action-label
{
-ms-flex
:
1
1
auto
;
flex
:
1
1
auto
;
...
...
src/vs/base/browser/ui/menu/menu.ts
浏览文件 @
b44e7d9f
...
...
@@ -6,12 +6,13 @@
'
use strict
'
;
import
'
vs/css!./menu
'
;
import
*
as
nls
from
'
vs/nls
'
;
import
{
IDisposable
}
from
'
vs/base/common/lifecycle
'
;
import
{
IActionRunner
,
IAction
,
Action
}
from
'
vs/base/common/actions
'
;
import
{
ActionBar
,
IActionItemProvider
,
ActionsOrientation
,
Separator
,
ActionItem
,
IActionItemOptions
}
from
'
vs/base/browser/ui/actionbar/actionbar
'
;
import
{
ActionBar
,
IActionItemProvider
,
ActionsOrientation
,
Separator
,
ActionItem
,
IActionItemOptions
,
BaseActionItem
}
from
'
vs/base/browser/ui/actionbar/actionbar
'
;
import
{
ResolvedKeybinding
,
KeyCode
}
from
'
vs/base/common/keyCodes
'
;
import
{
Event
}
from
'
vs/base/common/event
'
;
import
{
addClass
,
EventType
,
EventHelper
,
EventLike
}
from
'
vs/base/browser/dom
'
;
import
{
addClass
,
EventType
,
EventHelper
,
EventLike
,
removeTabIndexAndUpdateFocus
}
from
'
vs/base/browser/dom
'
;
import
{
StandardKeyboardEvent
}
from
'
vs/base/browser/keyboardEvent
'
;
import
{
$
,
Builder
}
from
'
vs/base/browser/builder
'
;
...
...
@@ -65,7 +66,7 @@ export class Menu {
this
.
actionBar
.
push
(
actions
,
{
icon
:
true
,
label
:
true
,
isMenu
:
true
});
}
private
doGetActionItem
(
action
:
IAction
,
options
:
IMenuOptions
,
parentData
:
ISubMenuData
):
ActionItem
{
private
doGetActionItem
(
action
:
IAction
,
options
:
IMenuOptions
,
parentData
:
ISubMenuData
):
Base
ActionItem
{
if
(
action
instanceof
Separator
)
{
return
new
ActionItem
(
options
.
context
,
action
,
{
icon
:
true
});
}
else
if
(
action
instanceof
SubmenuAction
)
{
...
...
@@ -110,42 +111,128 @@ export class Menu {
}
}
class
MenuActionItem
extends
ActionItem
{
class
MenuActionItem
extends
Base
ActionItem
{
static
MNEMONIC_REGEX
:
RegExp
=
/&&
(
.
)
/g
;
protected
$e
:
Builder
;
protected
$label
:
Builder
;
protected
options
:
IActionItemOptions
;
private
cssClass
:
string
;
constructor
(
ctx
:
any
,
action
:
IAction
,
options
:
IActionItemOptions
=
{})
{
options
.
isMenu
=
true
;
super
(
action
,
action
,
options
);
}
private
_addMnemonic
(
action
:
IAction
,
actionItemElement
:
HTMLElement
):
void
{
let
matches
=
MenuActionItem
.
MNEMONIC_REGEX
.
exec
(
action
.
label
);
if
(
matches
&&
matches
.
length
===
2
)
{
let
mnemonic
=
matches
[
1
];
this
.
options
=
options
;
this
.
options
.
icon
=
options
.
icon
!==
undefined
?
options
.
icon
:
false
;
this
.
options
.
label
=
options
.
label
!==
undefined
?
options
.
label
:
true
;
this
.
cssClass
=
''
;
}
let
ariaLabel
=
action
.
label
.
replace
(
MenuActionItem
.
MNEMONIC_REGEX
,
mnemonic
);
public
render
(
container
:
HTMLElement
):
void
{
super
.
render
(
container
);
actionItemElement
.
accessKey
=
mnemonic
.
toLocaleLowerCase
();
this
.
$e
.
attr
(
'
aria-label
'
,
ariaLabel
);
this
.
$e
=
$
(
'
a.action-menu-item
'
).
appendTo
(
this
.
builder
);
if
(
this
.
_action
.
id
===
Separator
.
ID
)
{
// A separator is a presentation item
this
.
$e
.
attr
({
role
:
'
presentation
'
});
}
else
{
this
.
$e
.
attr
(
'
aria-label
'
,
action
.
label
);
this
.
$e
.
attr
(
{
role
:
'
menuitem
'
}
);
}
}
public
render
(
container
:
HTMLElement
):
void
{
super
.
render
(
container
);
this
.
$label
=
$
(
'
span.action-label
'
).
appendTo
(
this
.
$e
);
this
.
_addMnemonic
(
this
.
getAction
(),
container
);
this
.
$e
.
attr
(
'
role
'
,
'
menuitem
'
);
if
(
this
.
options
.
label
&&
this
.
options
.
keybinding
)
{
$
(
'
span.keybinding
'
).
text
(
this
.
options
.
keybinding
).
appendTo
(
this
.
$e
);
}
this
.
_updateClass
();
this
.
_updateLabel
();
this
.
_updateTooltip
();
this
.
_updateEnabled
();
this
.
_updateChecked
();
}
public
focus
():
void
{
super
.
focus
();
this
.
$e
.
domFocus
();
}
public
_updateLabel
():
void
{
if
(
this
.
options
.
label
)
{
let
label
=
this
.
getAction
().
label
;
if
(
label
&&
this
.
options
.
isMenu
)
{
if
(
label
)
{
let
matches
=
MenuActionItem
.
MNEMONIC_REGEX
.
exec
(
label
);
if
(
matches
&&
matches
.
length
===
2
)
{
let
mnemonic
=
matches
[
1
];
let
ariaLabel
=
label
.
replace
(
MenuActionItem
.
MNEMONIC_REGEX
,
mnemonic
);
this
.
$e
.
getHTMLElement
().
accessKey
=
mnemonic
.
toLocaleLowerCase
();
this
.
$label
.
attr
(
'
aria-label
'
,
ariaLabel
);
}
else
{
this
.
$label
.
attr
(
'
aria-label
'
,
label
);
}
label
=
label
.
replace
(
MenuActionItem
.
MNEMONIC_REGEX
,
'
$1
\
u0332
'
);
}
this
.
$e
.
text
(
label
);
this
.
$label
.
text
(
label
);
}
}
public
_updateTooltip
():
void
{
let
title
:
string
=
null
;
if
(
this
.
getAction
().
tooltip
)
{
title
=
this
.
getAction
().
tooltip
;
}
else
if
(
!
this
.
options
.
label
&&
this
.
getAction
().
label
&&
this
.
options
.
icon
)
{
title
=
this
.
getAction
().
label
;
if
(
this
.
options
.
keybinding
)
{
title
=
nls
.
localize
({
key
:
'
titleLabel
'
,
comment
:
[
'
action title
'
,
'
action keybinding
'
]
},
"
{0} ({1})
"
,
title
,
this
.
options
.
keybinding
);
}
}
if
(
title
)
{
this
.
$e
.
attr
({
title
:
title
});
}
}
public
_updateClass
():
void
{
if
(
this
.
cssClass
)
{
this
.
$e
.
removeClass
(
this
.
cssClass
);
}
if
(
this
.
options
.
icon
)
{
this
.
cssClass
=
this
.
getAction
().
class
;
this
.
$label
.
addClass
(
'
icon
'
);
if
(
this
.
cssClass
)
{
this
.
$label
.
addClass
(
this
.
cssClass
);
}
this
.
_updateEnabled
();
}
else
{
this
.
$label
.
removeClass
(
'
icon
'
);
}
}
public
_updateEnabled
():
void
{
if
(
this
.
getAction
().
enabled
)
{
this
.
builder
.
removeClass
(
'
disabled
'
);
this
.
$e
.
removeClass
(
'
disabled
'
);
this
.
$e
.
attr
({
tabindex
:
0
});
}
else
{
this
.
builder
.
addClass
(
'
disabled
'
);
this
.
$e
.
addClass
(
'
disabled
'
);
removeTabIndexAndUpdateFocus
(
this
.
$e
.
getHTMLElement
());
}
}
public
_updateChecked
():
void
{
if
(
this
.
getAction
().
checked
)
{
this
.
$label
.
addClass
(
'
checked
'
);
}
else
{
this
.
$label
.
removeClass
(
'
checked
'
);
}
}
}
...
...
@@ -167,10 +254,9 @@ class SubmenuActionItem extends MenuActionItem {
public
render
(
container
:
HTMLElement
):
void
{
super
.
render
(
container
);
this
.
builder
=
$
(
container
);
$
(
this
.
builder
).
addClass
(
'
monaco-submenu-item
'
);
$
(
'
span.submenu-indicator
'
).
text
(
'
\
u25B6
'
).
appendTo
(
this
.
builder
);
this
.
$e
.
attr
(
'
role
'
,
'
menu
'
);
this
.
$e
.
addClass
(
'
monaco-submenu-item
'
);
this
.
$e
.
attr
(
'
aria-haspopup
'
,
'
true
'
);
$
(
'
span.submenu-indicator
'
).
text
(
'
\
u25B6
'
).
appendTo
(
this
.
$e
);
$
(
this
.
builder
).
on
(
EventType
.
KEY_UP
,
(
e
)
=>
{
let
event
=
new
StandardKeyboardEvent
(
e
as
KeyboardEvent
);
...
...
@@ -202,7 +288,6 @@ class SubmenuActionItem extends MenuActionItem {
}
});
$
(
this
.
builder
).
on
(
EventType
.
MOUSE_LEAVE
,
(
e
)
=>
{
this
.
mouseOver
=
false
;
...
...
@@ -219,6 +304,8 @@ class SubmenuActionItem extends MenuActionItem {
public
onClick
(
e
:
EventLike
)
{
// stop clicking from trying to run an action
EventHelper
.
stop
(
e
,
true
);
this
.
createSubmenu
();
}
private
cleanupExistingSubmenu
(
force
:
boolean
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录