Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
e6a29d19
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,发现更多精彩内容 >>
提交
e6a29d19
编写于
7月 13, 2016
作者:
B
Benjamin Pasero
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
find position of title area by walking up
上级
889e01a8
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
29 addition
and
11 deletion
+29
-11
src/vs/workbench/browser/parts/editor/sideBySideEditorControl.ts
...workbench/browser/parts/editor/sideBySideEditorControl.ts
+29
-11
未找到文件。
src/vs/workbench/browser/parts/editor/sideBySideEditorControl.ts
浏览文件 @
e6a29d19
...
...
@@ -33,7 +33,7 @@ import {IDisposable, dispose} from 'vs/base/common/lifecycle';
import
{
TabsTitleControl
}
from
'
vs/workbench/browser/parts/editor/tabsTitleControl
'
;
import
{
TitleControl
}
from
'
vs/workbench/browser/parts/editor/titleControl
'
;
import
{
NoTabsTitleControl
}
from
'
vs/workbench/browser/parts/editor/noTabsTitleControl
'
;
import
{
IEditorStacksModel
,
IStacksModelChangeEvent
,
IWorkbenchEditorConfiguration
}
from
'
vs/workbench/common/editor
'
;
import
{
IEditorStacksModel
,
IStacksModelChangeEvent
,
IWorkbenchEditorConfiguration
,
IEditorGroup
}
from
'
vs/workbench/common/editor
'
;
import
{
ITitleAreaControl
}
from
'
vs/workbench/browser/parts/editor/titleControl
'
;
import
{
extractResources
}
from
'
vs/base/browser/dnd
'
;
...
...
@@ -181,7 +181,7 @@ export class SideBySideEditorControl implements ISideBySideEditorControl, IVerti
titleContainer
.
empty
();
// Create new
this
.
createTitleControl
(
position
,
titleContainer
);
this
.
createTitleControl
(
this
.
stacks
.
groupAt
(
position
),
this
.
silos
[
position
],
titleContainer
,
this
.
getInstantiationService
(
position
)
);
}
}
});
...
...
@@ -730,9 +730,10 @@ export class SideBySideEditorControl implements ISideBySideEditorControl, IVerti
// For each position
const
useTabs
=
!!
this
.
configurationService
.
getConfiguration
<
IWorkbenchEditorConfiguration
>
().
workbench
.
editor
.
showTabs
;
POSITIONS
.
forEach
(
position
=>
{
const
silo
=
this
.
silos
[
position
];
// Containers (they contain everything and can move between silos)
const
container
=
$
(
this
.
silos
[
position
]
).
div
({
'
class
'
:
'
container
'
});
const
container
=
$
(
silo
).
div
({
'
class
'
:
'
container
'
});
// InstantiationServices
const
instantiationService
=
this
.
instantiationService
.
createChild
(
new
ServiceCollection
(
...
...
@@ -745,10 +746,10 @@ export class SideBySideEditorControl implements ISideBySideEditorControl, IVerti
if
(
useTabs
)
{
titleContainer
.
addClass
(
'
tabs
'
);
}
this
.
hookTitleDragListener
(
position
,
titleContainer
);
this
.
hookTitleDragListener
(
titleContainer
);
// Title Control
this
.
createTitleControl
(
position
,
titleContainer
);
this
.
createTitleControl
(
this
.
stacks
.
groupAt
(
position
),
silo
,
titleContainer
,
instantiationService
);
// Progress Bar
const
progressBar
=
new
ProgressBar
(
$
(
container
));
...
...
@@ -1003,22 +1004,39 @@ export class SideBySideEditorControl implements ISideBySideEditorControl, IVerti
});
}
private
createTitleControl
(
position
:
Position
,
container
:
Builder
):
void
{
private
createTitleControl
(
context
:
IEditorGroup
,
silo
:
Builder
,
container
:
Builder
,
instantiationService
:
IInstantiationService
):
void
{
const
useTabs
=
!!
this
.
configurationService
.
getConfiguration
<
IWorkbenchEditorConfiguration
>
().
workbench
.
editor
.
showTabs
;
const
titleAreaControl
=
this
.
getInstantiationService
(
position
)
.
createInstance
<
ITitleAreaControl
>
(
useTabs
?
TabsTitleControl
:
NoTabsTitleControl
);
const
titleAreaControl
=
instantiationService
.
createInstance
<
ITitleAreaControl
>
(
useTabs
?
TabsTitleControl
:
NoTabsTitleControl
);
titleAreaControl
.
create
(
container
.
getHTMLElement
());
titleAreaControl
.
setContext
(
this
.
stacks
.
groupAt
(
position
)
);
titleAreaControl
.
setContext
(
context
);
titleAreaControl
.
refresh
();
this
.
silos
[
position
]
.
child
().
setProperty
(
SideBySideEditorControl
.
TITLE_AREA_CONTROL_KEY
,
titleAreaControl
);
// associate with container
silo
.
child
().
setProperty
(
SideBySideEditorControl
.
TITLE_AREA_CONTROL_KEY
,
titleAreaControl
);
// associate with container
}
private
hookTitleDragListener
(
position
:
number
,
container
:
Builder
):
void
{
private
findPosition
(
element
:
HTMLElement
):
Position
{
let
parent
=
element
.
parentElement
;
while
(
parent
)
{
for
(
let
i
=
0
;
i
<
POSITIONS
.
length
;
i
++
)
{
const
position
=
POSITIONS
[
i
];
if
(
this
.
silos
[
position
].
getHTMLElement
()
===
parent
)
{
return
position
;
}
}
parent
=
parent
.
parentElement
;
}
return
null
;
}
private
hookTitleDragListener
(
titleContainer
:
Builder
):
void
{
let
wasDragged
=
false
;
// Allow to reorder positions by dragging the title
container
.
on
(
DOM
.
EventType
.
MOUSE_DOWN
,
(
e
:
MouseEvent
)
=>
{
titleContainer
.
on
(
DOM
.
EventType
.
MOUSE_DOWN
,
(
e
:
MouseEvent
)
=>
{
const
position
=
this
.
findPosition
(
titleContainer
.
getHTMLElement
());
if
(
!
this
.
getTitleAreaControl
(
position
).
allowDragging
(
<
any
>
e
.
target
||
e
.
srcElement
))
{
return
;
// return early if we are not in the drag zone of the title widget
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录