Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
130981bc
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,发现更多精彩内容 >>
提交
130981bc
编写于
3月 01, 2018
作者:
S
Sandeep Somavarapu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Revert to 1.20
上级
3c73a2d4
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
84 addition
and
1 deletion
+84
-1
src/vs/workbench/browser/parts/views/customView.ts
src/vs/workbench/browser/parts/views/customView.ts
+79
-1
src/vs/workbench/browser/parts/views/media/views.css
src/vs/workbench/browser/parts/views/media/views.css
+5
-0
未找到文件。
src/vs/workbench/browser/parts/views/customView.ts
浏览文件 @
130981bc
...
...
@@ -339,6 +339,7 @@ interface ITreeExplorerTemplateData {
resourceLabel
:
ResourceLabel
;
icon
:
HTMLElement
;
actionBar
:
ActionBar
;
aligner
:
Aligner
;
}
class
TreeRenderer
implements
IRenderer
{
...
...
@@ -375,7 +376,7 @@ class TreeRenderer implements IRenderer {
actionRunner
:
new
MultipleSelectionActionRunner
(()
=>
tree
.
getSelection
())
});
return
{
label
,
resourceLabel
,
icon
,
actionBar
};
return
{
label
,
resourceLabel
,
icon
,
actionBar
,
aligner
:
new
Aligner
(
container
,
tree
,
this
.
themeService
)
};
}
public
renderElement
(
tree
:
ITree
,
node
:
ITreeItem
,
templateId
:
string
,
templateData
:
ITreeExplorerTemplateData
):
void
{
...
...
@@ -404,6 +405,8 @@ class TreeRenderer implements IRenderer {
DOM
.
toggleClass
(
templateData
.
icon
,
'
custom-view-tree-node-item-icon
'
,
!!
icon
);
templateData
.
actionBar
.
context
=
(
<
TreeViewItemHandleArg
>
{
$treeViewId
:
this
.
treeViewId
,
$treeItemHandle
:
node
.
handle
});
templateData
.
actionBar
.
push
(
this
.
menus
.
getResourceActions
(
node
),
{
icon
:
true
,
label
:
false
});
templateData
.
aligner
.
align
(
node
);
}
private
getFileKind
(
node
:
ITreeItem
):
FileKind
{
...
...
@@ -421,6 +424,81 @@ class TreeRenderer implements IRenderer {
public
disposeTemplate
(
tree
:
ITree
,
templateId
:
string
,
templateData
:
ITreeExplorerTemplateData
):
void
{
templateData
.
resourceLabel
.
dispose
();
templateData
.
actionBar
.
dispose
();
templateData
.
aligner
.
dispose
();
}
}
class
Aligner
extends
Disposable
{
private
node
:
ITreeItem
;
constructor
(
private
container
:
HTMLElement
,
private
tree
:
ITree
,
private
themeService
:
IWorkbenchThemeService
)
{
super
();
this
.
_register
(
this
.
themeService
.
onDidFileIconThemeChange
(()
=>
this
.
alignByTheme
()));
}
align
(
treeItem
:
ITreeItem
):
void
{
this
.
node
=
treeItem
;
this
.
alignByTheme
();
}
private
alignByTheme
():
void
{
if
(
this
.
node
)
{
DOM
.
toggleClass
(
this
.
container
,
'
align-with-twisty
'
,
this
.
hasToAlignWithTwisty
());
}
}
private
hasToAlignWithTwisty
():
boolean
{
if
(
this
.
hasParentHasIcon
())
{
return
false
;
}
const
fileIconTheme
=
this
.
themeService
.
getFileIconTheme
();
if
(
!
(
fileIconTheme
.
hasFileIcons
&&
!
fileIconTheme
.
hasFolderIcons
))
{
return
false
;
}
if
(
this
.
node
.
collapsibleState
!==
TreeItemCollapsibleState
.
None
)
{
return
false
;
}
const
icon
=
this
.
themeService
.
getTheme
().
type
===
LIGHT
?
this
.
node
.
icon
:
this
.
node
.
iconDark
;
const
hasIcon
=
!!
icon
||
!!
this
.
node
.
resourceUri
;
if
(
!
hasIcon
)
{
return
false
;
}
const
siblingsWithChildren
=
this
.
getSiblings
().
filter
(
s
=>
s
.
collapsibleState
!==
TreeItemCollapsibleState
.
None
);
for
(
const
s
of
siblingsWithChildren
)
{
const
icon
=
this
.
themeService
.
getTheme
().
type
===
LIGHT
?
s
.
icon
:
s
.
iconDark
;
if
(
icon
)
{
return
false
;
}
}
return
true
;
}
private
getSiblings
():
ITreeItem
[]
{
const
parent
:
ITreeItem
=
this
.
tree
.
getNavigator
(
this
.
node
).
parent
()
||
this
.
tree
.
getInput
();
return
parent
.
children
;
}
private
hasParentHasIcon
():
boolean
{
const
parent
=
this
.
tree
.
getNavigator
(
this
.
node
).
parent
()
||
this
.
tree
.
getInput
();
const
icon
=
this
.
themeService
.
getTheme
().
type
===
LIGHT
?
parent
.
icon
:
parent
.
iconDark
;
if
(
icon
)
{
return
true
;
}
if
(
parent
.
resourceUri
)
{
const
fileIconTheme
=
this
.
themeService
.
getFileIconTheme
();
if
(
fileIconTheme
.
hasFileIcons
&&
fileIconTheme
.
hasFolderIcons
)
{
return
true
;
}
}
return
false
;
}
}
...
...
src/vs/workbench/browser/parts/views/media/views.css
浏览文件 @
130981bc
...
...
@@ -50,6 +50,11 @@
display
:
none
;
}
.tree-explorer-viewlet-tree-view.file-icon-themable-tree.align-icons-and-twisties
.monaco-tree-row
:not
(
.has-children
)
.content
:not
(
.align-with-twisty
)
::before
,
.tree-explorer-viewlet-tree-view.file-icon-themable-tree.hide-arrows
.monaco-tree-row
.content
::before
{
display
:
inline-block
;
}
.tree-explorer-viewlet-tree-view
.monaco-tree
.monaco-tree-row
.custom-view-tree-node-item
{
display
:
flex
;
height
:
22px
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录