Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
d5fc23ce
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,体验更适合开发者的 AI 搜索 >>
提交
d5fc23ce
编写于
1月 07, 2021
作者:
B
Benjamin Pasero
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Wrapping tabs: editor toolbar bleeds into tab when space is limited (fix #113926)
上级
14bb2fdc
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
30 addition
and
4 deletion
+30
-4
src/vs/workbench/browser/parts/editor/tabsTitleControl.ts
src/vs/workbench/browser/parts/editor/tabsTitleControl.ts
+30
-4
未找到文件。
src/vs/workbench/browser/parts/editor/tabsTitleControl.ts
浏览文件 @
d5fc23ce
...
...
@@ -1458,6 +1458,21 @@ export class TabsTitleControl extends TitleControl {
// be the width of the editor actions container to avoid screen cheese.
tabsContainer
.
style
.
setProperty
(
'
--last-tab-margin-right
'
,
tabsWrapMultiLine
?
`
${
editorToolbarContainer
.
offsetWidth
}
px`
:
'
0
'
);
// We need to disable wrapping also in case the last tab requires more
// width than what is available accounting for the available width and
// the editor toolbar.
// Workaround for https://github.com/microsoft/vscode/issues/113926
// An overall better fix is to make the editor toolbar a "fake" last tab
// so that it requires the space it needs, potentially wrapping to the
// next line (see https://github.com/microsoft/vscode/issues/113801)
const
lastTab
=
this
.
getLastTab
();
if
(
tabsWrapMultiLine
&&
lastTab
&&
lastTab
.
offsetWidth
>
(
dimensions
.
available
.
width
-
editorToolbarContainer
.
offsetWidth
))
{
tabsAndActionsContainer
.
classList
.
remove
(
'
wrapping
'
);
tabsWrapMultiLine
=
false
;
updateScrollbar
=
true
;
tabsContainer
.
style
.
setProperty
(
'
--last-tab-margin-right
'
,
'
0
'
);
}
// When tabs change from wrapping back to normal, we need to indicate this
// to the scrollbar so that revealing the active tab functions properly.
if
(
updateScrollbar
)
{
...
...
@@ -1547,17 +1562,28 @@ export class TabsTitleControl extends TitleControl {
private
getTabAndIndex
(
editor
:
IEditorInput
):
[
HTMLElement
,
number
/* index */
]
|
undefined
{
const
editorIndex
=
this
.
group
.
getIndexOfEditor
(
editor
);
const
tab
=
this
.
getTabAtIndex
(
editorIndex
);
if
(
tab
)
{
return
[
tab
,
editorIndex
];
}
return
undefined
;
}
private
getTabAtIndex
(
editorIndex
:
number
):
HTMLElement
|
undefined
{
if
(
editorIndex
>=
0
)
{
const
tabsContainer
=
assertIsDefined
(
this
.
tabsContainer
);
const
tab
=
tabsContainer
.
children
[
editorIndex
];
if
(
tab
)
{
return
[
tab
as
HTMLElement
,
editorIndex
];
}
return
tabsContainer
.
children
[
editorIndex
]
as
HTMLElement
|
undefined
;
}
return
undefined
;
}
private
getLastTab
():
HTMLElement
|
undefined
{
return
this
.
getTabAtIndex
(
this
.
group
.
count
-
1
);
}
private
blockRevealActiveTabOnce
():
void
{
// When closing tabs through the tab close button or gesture, the user
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录