Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
e4740f3f
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,发现更多精彩内容 >>
提交
e4740f3f
编写于
5月 17, 2018
作者:
I
isidor
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
open editors view: react on group events
上级
918aa637
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
30 addition
and
33 deletion
+30
-33
src/vs/workbench/parts/files/electron-browser/views/openEditorsView.ts
...nch/parts/files/electron-browser/views/openEditorsView.ts
+30
-33
未找到文件。
src/vs/workbench/parts/files/electron-browser/views/openEditorsView.ts
浏览文件 @
e4740f3f
...
...
@@ -89,19 +89,41 @@ export class OpenEditorsView extends ViewsViewletPanel {
this
.
needsRefresh
=
false
;
},
this
.
structuralRefreshDelay
);
// update on model changes
// TODO@Isidor handle model change events
// this.disposables.push(this.model.onModelChanged(e => this.onEditorStacksModelChanged(e)));
this
.
registerUpdateEvents
();
// Also handle configuration updates
this
.
disposables
.
push
(
this
.
configurationService
.
onDidChangeConfiguration
(
e
=>
this
.
onConfigurationChange
(
e
)));
// Handle dirty counter
this
.
disposables
.
push
(
this
.
untitledEditorService
.
onDidChangeDirty
(
e
=>
this
.
updateDirtyIndicator
()));
this
.
disposables
.
push
(
this
.
textFileService
.
models
.
onModelsDirty
(
e
=>
this
.
updateDirtyIndicator
()));
this
.
disposables
.
push
(
this
.
textFileService
.
models
.
onModelsSaved
(
e
=>
this
.
updateDirtyIndicator
()));
this
.
disposables
.
push
(
this
.
textFileService
.
models
.
onModelsSaveError
(
e
=>
this
.
updateDirtyIndicator
()));
this
.
disposables
.
push
(
this
.
textFileService
.
models
.
onModelsReverted
(
e
=>
this
.
updateDirtyIndicator
()));
this
.
disposables
.
push
(
this
.
untitledEditorService
.
onDidChangeDirty
(()
=>
this
.
updateDirtyIndicator
()));
this
.
disposables
.
push
(
this
.
textFileService
.
models
.
onModelsDirty
(()
=>
this
.
updateDirtyIndicator
()));
this
.
disposables
.
push
(
this
.
textFileService
.
models
.
onModelsSaved
(()
=>
this
.
updateDirtyIndicator
()));
this
.
disposables
.
push
(
this
.
textFileService
.
models
.
onModelsSaveError
(()
=>
this
.
updateDirtyIndicator
()));
this
.
disposables
.
push
(
this
.
textFileService
.
models
.
onModelsReverted
(()
=>
this
.
updateDirtyIndicator
()));
}
private
registerUpdateEvents
():
void
{
const
updateWholeList
=
()
=>
{
if
(
!
this
.
isVisible
()
||
!
this
.
list
||
!
this
.
isExpanded
())
{
this
.
needsRefresh
=
true
;
return
;
}
this
.
listRefreshScheduler
.
schedule
(
this
.
structuralRefreshDelay
);
};
this
.
disposables
.
push
(
this
.
editorGroupService
.
onDidAddGroup
(()
=>
updateWholeList
()));
this
.
disposables
.
push
(
this
.
editorGroupService
.
onDidMoveGroup
(()
=>
updateWholeList
()));
this
.
disposables
.
push
(
this
.
editorGroupService
.
onDidRemoveGroup
(()
=>
updateWholeList
()));
// TODO@isidor react on editor events
// this.disposables.push(this.editorService.onWillCloseEditor(e => {
// const group = this.editorGroupService.getGroup(e.groupId);
// const index = this.getIndex(group, e.editor);
// this.list.splice(index, 1);
// }));
// this.editorService.onWillOpenEditor(
// this.disposables.push(this.editorService.onDidActiveEditorChange(() => this.focusActiveEditor()));
}
protected
renderHeaderTitle
(
container
:
HTMLElement
):
void
{
...
...
@@ -312,31 +334,6 @@ export class OpenEditorsView extends ViewsViewletPanel {
});
}
// private onEditorStacksModelChanged(e: IStacksModelChangeEvent): void {
// if (!this.isVisible() || !this.list || !this.isExpanded()) {
// this.needsRefresh = true;
// return;
// }
// // Do a minimal list update based on if the change is structural or not #6670
// if (e.structural) {
// this.listRefreshScheduler.schedule(this.structuralRefreshDelay);
// } else if (!this.listRefreshScheduler.isScheduled()) {
// const newElement = e.editor ? new OpenEditor(e.editor, e.group) : this.showGroups ? e.group : undefined;
// if (newElement) {
// const index = this.getIndex(e.group, e.editor);
// const previousLength = this.list.length;
// this.list.splice(index, 1, [newElement]);
// if (previousLength !== this.list.length) {
// this.updateSize();
// }
// this.focusActiveEditor();
// }
// }
// }
private
focusActiveEditor
():
void
{
if
(
this
.
editorGroupService
.
activeGroup
&&
this
.
editorGroupService
.
activeGroup
.
activeEditor
/* could be empty */
)
{
const
index
=
this
.
getIndex
(
this
.
editorGroupService
.
activeGroup
,
this
.
editorGroupService
.
activeGroup
.
activeEditor
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录