Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
6c24b5d4
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,发现更多精彩内容 >>
提交
6c24b5d4
编写于
10月 04, 2018
作者:
J
Joao Moreno
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
tree test: setChildren on collapsed node
上级
e7d39fc6
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
30 addition
and
6 deletion
+30
-6
src/vs/base/browser/ui/tree/indexTreeModel.ts
src/vs/base/browser/ui/tree/indexTreeModel.ts
+9
-6
src/vs/base/test/browser/ui/tree/objectTreeModel.test.ts
src/vs/base/test/browser/ui/tree/objectTreeModel.test.ts
+21
-0
未找到文件。
src/vs/base/browser/ui/tree/indexTreeModel.ts
浏览文件 @
6c24b5d4
...
...
@@ -88,15 +88,18 @@ export class IndexTreeModel<T, TFilterData = void> implements ITreeModel<T, TFil
const
lastIndex
=
location
[
location
.
length
-
1
];
const
deletedNodes
=
parentNode
.
children
.
splice
(
lastIndex
,
deleteCount
,
...
nodesToInsert
);
const
visibleDeleteCount
=
deletedNodes
.
reduce
((
r
,
node
)
=>
r
+
node
.
revealedCount
,
0
);
this
.
_updateAncestorsRevealedCount
(
parentNode
,
revealedCount
-
visibleDeleteCount
);
if
(
!
parentNode
.
collapsed
)
{
const
visibleDeleteCount
=
deletedNodes
.
reduce
((
r
,
node
)
=>
r
+
node
.
revealedCount
,
0
);
if
(
revealed
)
{
this
.
list
.
splice
(
listIndex
,
visibleDeleteCount
,
treeListElementsToInsert
);
this
.
_updateAncestorsRevealedCount
(
parentNode
,
revealedCount
-
visibleDeleteCount
);
if
(
revealed
)
{
this
.
list
.
splice
(
listIndex
,
visibleDeleteCount
,
treeListElementsToInsert
);
}
}
if
(
onDidDeleteNode
)
{
if
(
deletedNodes
.
length
>
0
&&
onDidDeleteNode
)
{
const
visit
=
(
node
:
ITreeNode
<
T
,
TFilterData
>
)
=>
{
onDidDeleteNode
(
node
);
node
.
children
.
forEach
(
visit
);
...
...
@@ -187,7 +190,7 @@ export class IndexTreeModel<T, TFilterData = void> implements ITreeModel<T, TFil
element
:
treeElement
.
element
,
children
:
[],
depth
:
parent
.
depth
+
1
,
collapsible
:
!!
treeElement
.
collapsible
,
collapsible
:
typeof
treeElement
.
collapsible
===
'
boolean
'
?
treeElement
.
collapsible
:
(
typeof
treeElement
.
collapsed
===
'
boolean
'
)
,
collapsed
:
!!
treeElement
.
collapsed
,
revealedCount
:
1
,
visible
:
true
,
...
...
src/vs/base/test/browser/ui/tree/objectTreeModel.test.ts
浏览文件 @
6c24b5d4
...
...
@@ -93,4 +93,25 @@ suite('ObjectTreeModel', function () {
assert
.
deepEqual
(
toArray
(
list
),
[]);
assert
.
equal
(
model
.
size
,
0
);
});
test
(
'
setChildren on collapsed node
'
,
()
=>
{
const
list
=
[]
as
ITreeNode
<
number
>
[];
const
model
=
new
ObjectTreeModel
<
number
>
(
toSpliceable
(
list
));
model
.
setChildren
(
null
,
Iterator
.
fromArray
([
{
element
:
0
,
collapsed
:
true
}
]));
assert
.
deepEqual
(
toArray
(
list
),
[
0
]);
model
.
setChildren
(
0
,
Iterator
.
fromArray
([
{
element
:
1
},
{
element
:
2
}
]));
assert
.
deepEqual
(
toArray
(
list
),
[
0
]);
model
.
setCollapsed
(
0
,
false
);
assert
.
deepEqual
(
toArray
(
list
),
[
0
,
1
,
2
]);
});
});
\ No newline at end of file
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录