Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
3edd0f95
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,发现更多精彩内容 >>
提交
3edd0f95
编写于
6月 17, 2020
作者:
I
isidor
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
aria: use alternate containers such that duplicated messages get read out by screen readers
fixes #99466
上级
1a1b76f0
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
38 addition
and
14 deletion
+38
-14
src/vs/base/browser/ui/aria/aria.ts
src/vs/base/browser/ui/aria/aria.ts
+38
-14
未找到文件。
src/vs/base/browser/ui/aria/aria.ts
浏览文件 @
3edd0f95
...
...
@@ -11,32 +11,50 @@ import * as dom from 'vs/base/browser/dom';
const
MAX_MESSAGE_LENGTH
=
20000
;
let
ariaContainer
:
HTMLElement
;
let
alertContainer
:
HTMLElement
;
let
alertContainer2
:
HTMLElement
;
let
statusContainer
:
HTMLElement
;
let
statusContainer2
:
HTMLElement
;
export
function
setARIAContainer
(
parent
:
HTMLElement
)
{
ariaContainer
=
document
.
createElement
(
'
div
'
);
ariaContainer
.
className
=
'
monaco-aria-container
'
;
alertContainer
=
document
.
createElement
(
'
div
'
);
alertContainer
.
className
=
'
monaco-alert
'
;
alertContainer
.
setAttribute
(
'
role
'
,
'
alert
'
);
alertContainer
.
setAttribute
(
'
aria-atomic
'
,
'
true
'
);
ariaContainer
.
appendChild
(
alertContainer
);
const
createAlertContainer
=
()
=>
{
const
element
=
document
.
createElement
(
'
div
'
);
element
.
className
=
'
monaco-alert
'
;
element
.
setAttribute
(
'
role
'
,
'
alert
'
);
element
.
setAttribute
(
'
aria-atomic
'
,
'
true
'
);
ariaContainer
.
appendChild
(
element
);
return
element
;
};
alertContainer
=
createAlertContainer
();
alertContainer2
=
createAlertContainer
();
statusContainer
=
document
.
createElement
(
'
div
'
);
statusContainer
.
className
=
'
monaco-status
'
;
statusContainer
.
setAttribute
(
'
role
'
,
'
complementary
'
);
statusContainer
.
setAttribute
(
'
aria-live
'
,
'
polite
'
);
statusContainer
.
setAttribute
(
'
aria-atomic
'
,
'
true
'
);
ariaContainer
.
appendChild
(
statusContainer
);
const
createStatusContainer
=
()
=>
{
const
element
=
document
.
createElement
(
'
div
'
);
element
.
className
=
'
monaco-status
'
;
element
.
setAttribute
(
'
role
'
,
'
complementary
'
);
element
.
setAttribute
(
'
aria-live
'
,
'
polite
'
);
element
.
setAttribute
(
'
aria-atomic
'
,
'
true
'
);
ariaContainer
.
appendChild
(
element
);
return
element
;
};
statusContainer
=
createStatusContainer
();
statusContainer2
=
createStatusContainer
();
parent
.
appendChild
(
ariaContainer
);
}
/**
* Given the provided message, will make sure that it is read as alert to screen readers.
*/
export
function
alert
(
msg
:
string
):
void
{
insertMessage
(
alertContainer
,
msg
);
// Use alternate containers such that duplicated messages get read out by screen readers #99466
if
(
alertContainer
.
textContent
!==
msg
)
{
dom
.
clearNode
(
alertContainer2
);
insertMessage
(
alertContainer
,
msg
);
}
else
{
dom
.
clearNode
(
alertContainer
);
insertMessage
(
alertContainer2
,
msg
);
}
}
/**
...
...
@@ -46,7 +64,13 @@ export function status(msg: string): void {
if
(
isMacintosh
)
{
alert
(
msg
);
// VoiceOver does not seem to support status role
}
else
{
insertMessage
(
statusContainer
,
msg
);
if
(
statusContainer
.
textContent
!==
msg
)
{
dom
.
clearNode
(
statusContainer2
);
insertMessage
(
statusContainer
,
msg
);
}
else
{
dom
.
clearNode
(
statusContainer
);
insertMessage
(
statusContainer2
,
msg
);
}
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录