Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
a07aaa52
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,发现更多精彩内容 >>
提交
a07aaa52
编写于
5月 06, 2016
作者:
B
Benjamin Pasero
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add methods to close editors in group and close all groups; closing a group closes editors within
上级
c7a96a43
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
46 addition
and
18 deletion
+46
-18
src/vs/workbench/common/editor/editorStacksModel.ts
src/vs/workbench/common/editor/editorStacksModel.ts
+21
-18
src/vs/workbench/test/common/editor/editorStacksModel.test.ts
...vs/workbench/test/common/editor/editorStacksModel.test.ts
+25
-0
未找到文件。
src/vs/workbench/common/editor/editorStacksModel.ts
浏览文件 @
a07aaa52
...
...
@@ -32,6 +32,7 @@ export interface IEditorGroup {
getEditors
(
mru
?:
boolean
):
EditorInput
[];
openEditor
(
editor
:
EditorInput
,
options
?:
IEditorOpenOptions
):
void
;
closeEditor
(
editor
:
EditorInput
):
void
;
closeAllEditors
():
void
;
setActive
(
editor
:
EditorInput
):
void
;
isActive
(
editor
:
EditorInput
):
boolean
;
isPreview
(
editor
:
EditorInput
):
boolean
;
...
...
@@ -51,7 +52,10 @@ export interface IEditorStacksModel {
activeGroup
:
IEditorGroup
;
openGroup
(
label
:
string
):
IEditorGroup
;
closeGroup
(
group
:
IEditorGroup
):
void
;
closeAllGroups
():
void
;
setActive
(
group
:
IEditorGroup
):
void
;
}
...
...
@@ -62,28 +66,10 @@ export interface IEditorOpenOptions {
/// --- API-End ----
// N Groups with labels (start with Left, Center, Right)
// Group has a List of editors
// Group can have N editors state pinned and 1 state preview
// Group has 1 active edutir
// Group has MRV(isible) list of editors
// Model has actions to work with inputs
// Open
// To the left / to the right (setting)
// Close
// Close Others
// Close Editors to the Right
// Close All
// Close All in Group
// Move Editor
// Move Group
// Pin Editor
// Unpin Editor
// Model has resulting events from operations
// Can be serialized and restored
export
enum
Direction
{
LEFT
,
...
...
@@ -292,6 +278,13 @@ export class EditorGroup implements IEditorGroup {
this
.
_onEditorClosed
.
fire
(
editor
);
}
public
closeAllEditors
():
void
{
// Optimize: close all non active editors first to produce less upstream work
this
.
mru
.
filter
(
e
=>
e
!==
this
.
active
).
forEach
(
e
=>
this
.
closeEditor
(
e
));
this
.
closeEditor
(
this
.
active
);
}
public
setActive
(
editor
:
EditorInput
):
void
{
const
index
=
this
.
indexOf
(
editor
);
if
(
index
===
-
1
)
{
...
...
@@ -564,6 +557,9 @@ export class EditorStacksModel implements IEditorStacksModel {
}
}
// Close Editors in Group first
group
.
closeAllEditors
();
// Splice from groups
this
.
_groups
.
splice
(
index
,
1
);
...
...
@@ -571,6 +567,13 @@ export class EditorStacksModel implements IEditorStacksModel {
this
.
_onGroupClosed
.
fire
(
group
);
}
public
closeAllGroups
():
void
{
// Optimize: close all non active groups first to produce less upstream work
this
.
groups
.
filter
(
g
=>
g
!==
this
.
active
).
forEach
(
g
=>
this
.
closeGroup
(
g
));
this
.
closeGroup
(
this
.
active
);
}
public
setActive
(
group
:
EditorGroup
):
void
{
this
.
active
=
group
;
...
...
src/vs/workbench/test/common/editor/editorStacksModel.test.ts
浏览文件 @
a07aaa52
...
...
@@ -178,6 +178,20 @@ suite('Editor Stacks Model', () => {
assert
.
equal
(
fourth
,
model
.
activeGroup
);
model
.
closeGroup
(
fourth
);
assert
.
equal
(
second
,
model
.
activeGroup
);
model
.
closeGroup
(
second
);
assert
.
equal
(
model
.
groups
.
length
,
0
);
model
.
openGroup
(
'
first
'
);
model
.
openGroup
(
'
second
'
);
model
.
openGroup
(
'
third
'
);
model
.
openGroup
(
'
fourth
'
);
assert
.
equal
(
model
.
groups
.
length
,
4
);
model
.
closeAllGroups
();
assert
.
equal
(
model
.
groups
.
length
,
0
);
});
test
(
'
Stack - One Editor
'
,
function
()
{
...
...
@@ -319,6 +333,11 @@ suite('Editor Stacks Model', () => {
assert
.
equal
(
mru
[
0
],
input3
);
assert
.
equal
(
mru
[
1
],
input2
);
assert
.
equal
(
mru
[
2
],
input1
);
group
.
closeAllEditors
();
assert
.
equal
(
events
.
closed
.
length
,
3
);
assert
.
equal
(
group
.
count
,
0
);
});
test
(
'
Stack - Multiple Editors - Pinned and Active (DEFAULT_OPEN_EDITOR_DIRECTION = Direction.LEFT)
'
,
function
()
{
...
...
@@ -326,6 +345,7 @@ suite('Editor Stacks Model', () => {
const
model
=
create
();
const
group
=
model
.
openGroup
(
'
group
'
);
const
events
=
groupListener
(
group
);
const
input1
=
input
();
const
input2
=
input
();
...
...
@@ -339,6 +359,11 @@ suite('Editor Stacks Model', () => {
assert
.
equal
(
group
.
getEditors
()[
0
],
input3
);
assert
.
equal
(
group
.
getEditors
()[
1
],
input2
);
assert
.
equal
(
group
.
getEditors
()[
2
],
input1
);
model
.
closeAllGroups
();
assert
.
equal
(
events
.
closed
.
length
,
3
);
assert
.
equal
(
group
.
count
,
0
);
});
test
(
'
Stack - Multiple Editors - Pinned and Not Active
'
,
function
()
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录