Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
e85f2a3b
V
vscode
项目概览
掘金者说
/
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,发现更多精彩内容 >>
提交
e85f2a3b
编写于
9月 05, 2019
作者:
S
Sandeep Somavarapu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
💄
上级
f2ccbad2
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
40 addition
and
12 deletion
+40
-12
src/vs/workbench/contrib/markers/browser/markersPanel.ts
src/vs/workbench/contrib/markers/browser/markersPanel.ts
+40
-12
未找到文件。
src/vs/workbench/contrib/markers/browser/markersPanel.ts
浏览文件 @
e85f2a3b
...
@@ -25,9 +25,9 @@ import { IStorageService, StorageScope } from 'vs/platform/storage/common/storag
...
@@ -25,9 +25,9 @@ import { IStorageService, StorageScope } from 'vs/platform/storage/common/storag
import
{
localize
}
from
'
vs/nls
'
;
import
{
localize
}
from
'
vs/nls
'
;
import
{
IContextKey
,
IContextKeyService
}
from
'
vs/platform/contextkey/common/contextkey
'
;
import
{
IContextKey
,
IContextKeyService
}
from
'
vs/platform/contextkey/common/contextkey
'
;
import
{
Iterator
}
from
'
vs/base/common/iterator
'
;
import
{
Iterator
}
from
'
vs/base/common/iterator
'
;
import
{
ITreeElement
,
ITreeNode
,
ITreeContextMenuEvent
}
from
'
vs/base/browser/ui/tree/tree
'
;
import
{
ITreeElement
,
ITreeNode
,
ITreeContextMenuEvent
,
ITreeRenderer
}
from
'
vs/base/browser/ui/tree/tree
'
;
import
{
Relay
,
Event
,
Emitter
}
from
'
vs/base/common/event
'
;
import
{
Relay
,
Event
,
Emitter
}
from
'
vs/base/common/event
'
;
import
{
WorkbenchObjectTree
,
TreeResourceNavigator2
}
from
'
vs/platform/list/browser/listService
'
;
import
{
WorkbenchObjectTree
,
TreeResourceNavigator2
,
IListService
}
from
'
vs/platform/list/browser/listService
'
;
import
{
FilterOptions
}
from
'
vs/workbench/contrib/markers/browser/markersFilterOptions
'
;
import
{
FilterOptions
}
from
'
vs/workbench/contrib/markers/browser/markersFilterOptions
'
;
import
{
IExpression
}
from
'
vs/base/common/glob
'
;
import
{
IExpression
}
from
'
vs/base/common/glob
'
;
import
{
deepClone
}
from
'
vs/base/common/objects
'
;
import
{
deepClone
}
from
'
vs/base/common/objects
'
;
...
@@ -44,6 +44,9 @@ import { ResourceLabels } from 'vs/workbench/browser/labels';
...
@@ -44,6 +44,9 @@ import { ResourceLabels } from 'vs/workbench/browser/labels';
import
{
IMarker
}
from
'
vs/platform/markers/common/markers
'
;
import
{
IMarker
}
from
'
vs/platform/markers/common/markers
'
;
import
{
withUndefinedAsNull
}
from
'
vs/base/common/types
'
;
import
{
withUndefinedAsNull
}
from
'
vs/base/common/types
'
;
import
{
MementoObject
}
from
'
vs/workbench/common/memento
'
;
import
{
MementoObject
}
from
'
vs/workbench/common/memento
'
;
import
{
IListVirtualDelegate
}
from
'
vs/base/browser/ui/list/list
'
;
import
{
IObjectTreeOptions
}
from
'
vs/base/browser/ui/tree/objectTree
'
;
import
{
IAccessibilityService
}
from
'
vs/platform/accessibility/common/accessibility
'
;
function
createModelIterator
(
model
:
MarkersModel
):
Iterator
<
ITreeElement
<
TreeElement
>>
{
function
createModelIterator
(
model
:
MarkersModel
):
Iterator
<
ITreeElement
<
TreeElement
>>
{
const
resourcesIt
=
Iterator
.
fromArray
(
model
.
resourceMarkers
);
const
resourcesIt
=
Iterator
.
fromArray
(
model
.
resourceMarkers
);
...
@@ -71,8 +74,7 @@ export class MarkersPanel extends Panel implements IMarkerFilterController {
...
@@ -71,8 +74,7 @@ export class MarkersPanel extends Panel implements IMarkerFilterController {
private
readonly
rangeHighlightDecorations
:
RangeHighlightDecorations
;
private
readonly
rangeHighlightDecorations
:
RangeHighlightDecorations
;
private
readonly
filter
:
Filter
;
private
readonly
filter
:
Filter
;
private
tree
!
:
WorkbenchObjectTree
<
TreeElement
,
FilterData
>
;
private
tree
!
:
MarkersTree
;
private
treeContainer
!
:
HTMLElement
;
private
messageBoxContainer
!
:
HTMLElement
;
private
messageBoxContainer
!
:
HTMLElement
;
private
ariaLabelElement
!
:
HTMLElement
;
private
ariaLabelElement
!
:
HTMLElement
;
...
@@ -153,7 +155,6 @@ export class MarkersPanel extends Panel implements IMarkerFilterController {
...
@@ -153,7 +155,6 @@ export class MarkersPanel extends Panel implements IMarkerFilterController {
}
}
public
layout
(
dimension
:
dom
.
Dimension
):
void
{
public
layout
(
dimension
:
dom
.
Dimension
):
void
{
this
.
treeContainer
.
style
.
height
=
`
${
dimension
.
height
}
px`
;
this
.
tree
.
layout
(
dimension
.
height
,
dimension
.
width
);
this
.
tree
.
layout
(
dimension
.
height
,
dimension
.
width
);
if
(
this
.
filterInputActionViewItem
)
{
if
(
this
.
filterInputActionViewItem
)
{
this
.
filterInputActionViewItem
.
toggleLayout
(
dimension
.
width
<
1200
);
this
.
filterInputActionViewItem
.
toggleLayout
(
dimension
.
width
<
1200
);
...
@@ -252,7 +253,7 @@ export class MarkersPanel extends Panel implements IMarkerFilterController {
...
@@ -252,7 +253,7 @@ export class MarkersPanel extends Panel implements IMarkerFilterController {
}
}
const
{
total
,
filtered
}
=
this
.
getFilterStats
();
const
{
total
,
filtered
}
=
this
.
getFilterStats
();
dom
.
toggleClass
(
this
.
treeContainer
,
'
hidden
'
,
total
===
0
||
filtered
===
0
);
this
.
tree
.
toggleVisibility
(
total
===
0
||
filtered
===
0
);
this
.
renderMessage
();
this
.
renderMessage
();
this
.
_onDidFilter
.
fire
();
this
.
_onDidFilter
.
fire
();
}
}
...
@@ -269,7 +270,7 @@ export class MarkersPanel extends Panel implements IMarkerFilterController {
...
@@ -269,7 +270,7 @@ export class MarkersPanel extends Panel implements IMarkerFilterController {
this
.
_onDidFilter
.
fire
();
this
.
_onDidFilter
.
fire
();
const
{
total
,
filtered
}
=
this
.
getFilterStats
();
const
{
total
,
filtered
}
=
this
.
getFilterStats
();
dom
.
toggleClass
(
this
.
treeContainer
,
'
hidden
'
,
total
===
0
||
filtered
===
0
);
this
.
tree
.
toggleVisibility
(
total
===
0
||
filtered
===
0
);
this
.
renderMessage
();
this
.
renderMessage
();
}
}
...
@@ -300,8 +301,6 @@ export class MarkersPanel extends Panel implements IMarkerFilterController {
...
@@ -300,8 +301,6 @@ export class MarkersPanel extends Panel implements IMarkerFilterController {
}
}
private
createTree
(
parent
:
HTMLElement
):
void
{
private
createTree
(
parent
:
HTMLElement
):
void
{
this
.
treeContainer
=
dom
.
append
(
parent
,
dom
.
$
(
'
.tree-container.show-file-icons
'
));
const
onDidChangeRenderNodeCount
=
new
Relay
<
ITreeNode
<
any
,
any
>>
();
const
onDidChangeRenderNodeCount
=
new
Relay
<
ITreeNode
<
any
,
any
>>
();
const
treeLabels
=
this
.
_register
(
this
.
instantiationService
.
createInstance
(
ResourceLabels
,
this
));
const
treeLabels
=
this
.
_register
(
this
.
instantiationService
.
createInstance
(
ResourceLabels
,
this
));
...
@@ -320,9 +319,9 @@ export class MarkersPanel extends Panel implements IMarkerFilterController {
...
@@ -320,9 +319,9 @@ export class MarkersPanel extends Panel implements IMarkerFilterController {
}
}
};
};
this
.
tree
=
this
.
_register
(
this
.
instantiationService
.
createInstance
(
WorkbenchObject
Tree
,
this
.
tree
=
this
.
_register
(
this
.
instantiationService
.
createInstance
(
Markers
Tree
,
'
MarkersPanel
'
,
'
MarkersPanel
'
,
this
.
treeContainer
,
dom
.
append
(
parent
,
dom
.
$
(
'
.tree-container.show-file-icons
'
))
,
virtualDelegate
,
virtualDelegate
,
renderers
,
renderers
,
{
{
...
@@ -476,7 +475,7 @@ export class MarkersPanel extends Panel implements IMarkerFilterController {
...
@@ -476,7 +475,7 @@ export class MarkersPanel extends Panel implements IMarkerFilterController {
private
render
():
void
{
private
render
():
void
{
this
.
cachedFilterStats
=
undefined
;
this
.
cachedFilterStats
=
undefined
;
this
.
tree
.
setChildren
(
null
,
createModelIterator
(
this
.
markersWorkbenchService
.
markersModel
));
this
.
tree
.
setChildren
(
null
,
createModelIterator
(
this
.
markersWorkbenchService
.
markersModel
));
dom
.
toggleClass
(
this
.
treeContainer
,
'
hidden
'
,
this
.
isEmpty
());
this
.
tree
.
toggleVisibility
(
this
.
isEmpty
());
this
.
renderMessage
();
this
.
renderMessage
();
}
}
...
@@ -727,3 +726,32 @@ export class MarkersPanel extends Panel implements IMarkerFilterController {
...
@@ -727,3 +726,32 @@ export class MarkersPanel extends Panel implements IMarkerFilterController {
}
}
}
}
class
MarkersTree
extends
WorkbenchObjectTree
<
TreeElement
,
FilterData
>
{
constructor
(
user
:
string
,
readonly
container
:
HTMLElement
,
delegate
:
IListVirtualDelegate
<
TreeElement
>
,
renderers
:
ITreeRenderer
<
TreeElement
,
FilterData
,
any
>
[],
options
:
IObjectTreeOptions
<
TreeElement
,
FilterData
>
,
@
IContextKeyService
contextKeyService
:
IContextKeyService
,
@
IListService
listService
:
IListService
,
@
IThemeService
themeService
:
IThemeService
,
@
IConfigurationService
configurationService
:
IConfigurationService
,
@
IKeybindingService
keybindingService
:
IKeybindingService
,
@
IAccessibilityService
accessibilityService
:
IAccessibilityService
)
{
super
(
user
,
container
,
delegate
,
renderers
,
options
,
contextKeyService
,
listService
,
themeService
,
configurationService
,
keybindingService
,
accessibilityService
);
}
layout
(
height
:
number
,
width
:
number
):
void
{
this
.
container
.
style
.
height
=
`
${
height
}
px`
;
super
.
layout
(
height
,
width
);
}
toggleVisibility
(
hide
:
boolean
):
void
{
dom
.
toggleClass
(
this
.
container
,
'
hidden
'
,
hide
);
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录