Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
e50ef11f
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,发现更多精彩内容 >>
提交
e50ef11f
编写于
2月 05, 2019
作者:
J
Joao Moreno
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
tree: refactor click handling for expansion
上级
cf72cc41
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
65 addition
and
49 deletion
+65
-49
src/vs/base/browser/ui/list/listWidget.ts
src/vs/base/browser/ui/list/listWidget.ts
+20
-20
src/vs/base/browser/ui/tree/abstractTree.ts
src/vs/base/browser/ui/tree/abstractTree.ts
+45
-29
未找到文件。
src/vs/base/browser/ui/list/listWidget.ts
浏览文件 @
e50ef11f
...
...
@@ -502,33 +502,29 @@ const DefaultOpenController: IOpenController = {
}
};
class
MouseController
<
T
>
implements
IDisposable
{
export
class
MouseController
<
T
>
implements
IDisposable
{
private
multipleSelectionSupport
:
boolean
;
readonly
multipleSelectionController
:
IMultipleSelectionController
<
T
>
;
private
openController
:
IOpenController
;
private
disposables
:
IDisposable
[]
=
[];
constructor
(
private
list
:
List
<
T
>
,
private
view
:
ListView
<
T
>
,
options
:
IListOptions
<
T
>
=
{}
)
{
this
.
multipleSelectionSupport
=
!
(
options
.
multipleSelectionSupport
===
false
);
constructor
(
protected
list
:
List
<
T
>
)
{
this
.
multipleSelectionSupport
=
!
(
list
.
options
.
multipleSelectionSupport
===
false
);
if
(
this
.
multipleSelectionSupport
)
{
this
.
multipleSelectionController
=
options
.
multipleSelectionController
||
DefaultMultipleSelectionContoller
;
this
.
multipleSelectionController
=
list
.
options
.
multipleSelectionController
||
DefaultMultipleSelectionContoller
;
}
this
.
openController
=
options
.
openController
||
DefaultOpenController
;
this
.
openController
=
list
.
options
.
openController
||
DefaultOpenController
;
view
.
onMouseDown
(
this
.
onMouseDown
,
this
,
this
.
disposables
);
view
.
onContextMenu
(
this
.
onContextMenu
,
this
,
this
.
disposables
);
view
.
onMouseClick
(
this
.
onPointer
,
this
,
this
.
disposables
);
view
.
onMouseDblClick
(
this
.
onDoubleClick
,
this
,
this
.
disposables
);
view
.
onTouchStart
(
this
.
onMouseDown
,
this
,
this
.
disposables
);
view
.
onTap
(
this
.
onPointer
,
this
,
this
.
disposables
);
Gesture
.
addTarget
(
view
.
domNode
);
list
.
onMouseDown
(
this
.
onMouseDown
,
this
,
this
.
disposables
);
list
.
onContextMenu
(
this
.
onContextMenu
,
this
,
this
.
disposables
);
list
.
onMouseClick
(
this
.
onPointer
,
this
,
this
.
disposables
);
list
.
onMouseDblClick
(
this
.
onDoubleClick
,
this
,
this
.
disposables
);
list
.
onTouchStart
(
this
.
onMouseDown
,
this
,
this
.
disposables
);
list
.
onTap
(
this
.
onPointer
,
this
,
this
.
disposables
);
Gesture
.
addTarget
(
list
.
getHTMLElement
()
);
}
private
isSelectionSingleChangeEvent
(
event
:
IListMouseEvent
<
any
>
|
IListTouchEvent
<
any
>
):
boolean
{
...
...
@@ -553,16 +549,16 @@ class MouseController<T> implements IDisposable {
private
onMouseDown
(
e
:
IListMouseEvent
<
T
>
|
IListTouchEvent
<
T
>
):
void
{
if
(
document
.
activeElement
!==
e
.
browserEvent
.
target
)
{
this
.
view
.
domNode
.
f
ocus
();
this
.
list
.
domF
ocus
();
}
}
private
onContextMenu
(
e
:
IList
MouseEvent
<
T
>
|
IListTouch
Event
<
T
>
):
void
{
private
onContextMenu
(
e
:
IList
ContextMenu
Event
<
T
>
):
void
{
const
focus
=
typeof
e
.
index
===
'
undefined
'
?
[]
:
[
e
.
index
];
this
.
list
.
setFocus
(
focus
,
e
.
browserEvent
);
}
pr
ivate
onPointer
(
e
:
IListMouseEvent
<
T
>
):
void
{
pr
otected
onPointer
(
e
:
IListMouseEvent
<
T
>
):
void
{
let
reference
=
this
.
list
.
getFocus
()[
0
];
const
selection
=
this
.
list
.
getSelection
();
reference
=
reference
===
undefined
?
selection
[
0
]
:
reference
;
...
...
@@ -1213,7 +1209,7 @@ export class List<T> implements ISpliceable<T>, IDisposable {
}
if
(
typeof
_options
.
mouseSupport
===
'
boolean
'
?
_options
.
mouseSupport
:
true
)
{
this
.
mouseController
=
new
MouseController
(
this
,
this
.
view
,
_options
);
this
.
mouseController
=
this
.
createMouseController
(
_options
);
this
.
disposables
.
push
(
this
.
mouseController
);
}
...
...
@@ -1227,6 +1223,10 @@ export class List<T> implements ISpliceable<T>, IDisposable {
this
.
style
(
_options
);
}
protected
createMouseController
(
options
:
IListOptions
<
T
>
):
MouseController
<
T
>
{
return
new
MouseController
(
this
);
}
updateOptions
(
optionsUpdate
:
IListOptionsUpdate
=
{}):
void
{
this
.
_options
=
{
...
this
.
_options
,
...
optionsUpdate
};
this
.
_onDidUpdateOptions
.
fire
(
this
.
_options
);
...
...
src/vs/base/browser/ui/tree/abstractTree.ts
浏览文件 @
e50ef11f
...
...
@@ -5,7 +5,7 @@
import
'
vs/css!./media/tree
'
;
import
{
IDisposable
,
dispose
,
Disposable
,
toDisposable
}
from
'
vs/base/common/lifecycle
'
;
import
{
IListOptions
,
List
,
IListStyles
,
mightProducePrintableCharacter
}
from
'
vs/base/browser/ui/list/listWidget
'
;
import
{
IListOptions
,
List
,
IListStyles
,
mightProducePrintableCharacter
,
MouseController
}
from
'
vs/base/browser/ui/list/listWidget
'
;
import
{
IListVirtualDelegate
,
IListRenderer
,
IListMouseEvent
,
IListEvent
,
IListContextMenuEvent
,
IListDragAndDrop
,
IListDragOverReaction
,
IKeyboardNavigationLabelProvider
}
from
'
vs/base/browser/ui/list/list
'
;
import
{
append
,
$
,
toggleClass
,
getDomNodePagePosition
,
removeClass
,
addClass
}
from
'
vs/base/browser/dom
'
;
import
{
Event
,
Relay
,
Emitter
,
EventBufferer
}
from
'
vs/base/common/event
'
;
...
...
@@ -761,11 +761,47 @@ class Trait<T> {
}
}
export
class
TreeNodeListMouseController
<
T
,
TFilterData
,
TRef
>
extends
MouseController
<
ITreeNode
<
T
,
TFilterData
>>
{
constructor
(
list
:
TreeNodeList
<
T
,
TFilterData
,
TRef
>
,
private
tree
:
AbstractTree
<
T
,
TFilterData
,
TRef
>
)
{
super
(
list
);
}
protected
onPointer
(
e
:
IListMouseEvent
<
ITreeNode
<
T
,
TFilterData
>>
):
void
{
const
node
=
e
.
element
;
if
(
!
node
)
{
super
.
onPointer
(
e
);
return
;
}
if
(
this
.
multipleSelectionController
.
isSelectionRangeChangeEvent
(
e
)
||
this
.
multipleSelectionController
.
isSelectionSingleChangeEvent
(
e
))
{
super
.
onPointer
(
e
);
return
;
}
if
(
!
this
.
tree
.
options
.
openOnSingleClick
&&
e
.
browserEvent
.
detail
!==
2
)
{
super
.
onPointer
(
e
);
return
;
}
const
model
=
((
this
.
tree
as
any
).
model
as
ITreeModel
<
T
,
TFilterData
,
TRef
>
);
// internal
const
location
=
model
.
getNodeLocation
(
node
);
const
recursive
=
e
.
browserEvent
.
altKey
;
model
.
setCollapsed
(
location
,
undefined
,
recursive
);
super
.
onPointer
(
e
);
}
}
interface
ITreeNodeListOptions
<
T
,
TFilterData
,
TRef
>
extends
IListOptions
<
ITreeNode
<
T
,
TFilterData
>>
{
readonly
tree
:
AbstractTree
<
T
,
TFilterData
,
TRef
>
;
}
/**
* We use this List subclass to restore selection and focus as nodes
* get rendered in the list, possibly due to a node expand() call.
*/
class
TreeNodeList
<
T
,
TFilterData
>
extends
List
<
ITreeNode
<
T
,
TFilterData
>>
{
class
TreeNodeList
<
T
,
TFilterData
,
TRef
>
extends
List
<
ITreeNode
<
T
,
TFilterData
>>
{
constructor
(
container
:
HTMLElement
,
...
...
@@ -773,11 +809,15 @@ class TreeNodeList<T, TFilterData> extends List<ITreeNode<T, TFilterData>> {
renderers
:
IListRenderer
<
any
/* TODO@joao */
,
any
>
[],
private
focusTrait
:
Trait
<
T
>
,
private
selectionTrait
:
Trait
<
T
>
,
options
?:
IListOptions
<
ITreeNode
<
T
,
TFilterData
>
>
options
:
ITreeNodeListOptions
<
T
,
TFilterData
,
TRef
>
)
{
super
(
container
,
virtualDelegate
,
renderers
,
options
);
}
protected
createMouseController
(
options
:
ITreeNodeListOptions
<
T
,
TFilterData
,
TRef
>
):
MouseController
<
ITreeNode
<
T
,
TFilterData
>>
{
return
new
TreeNodeListMouseController
(
this
,
options
.
tree
);
}
splice
(
start
:
number
,
deleteCount
:
number
,
elements
:
ITreeNode
<
T
,
TFilterData
>
[]
=
[]):
void
{
super
.
splice
(
start
,
deleteCount
,
elements
);
...
...
@@ -826,7 +866,7 @@ class TreeNodeList<T, TFilterData> extends List<ITreeNode<T, TFilterData>> {
export
abstract
class
AbstractTree
<
T
,
TFilterData
,
TRef
>
implements
IDisposable
{
private
view
:
TreeNodeList
<
T
,
TFilterData
>
;
private
view
:
TreeNodeList
<
T
,
TFilterData
,
TRef
>
;
private
renderers
:
TreeRenderer
<
T
,
TFilterData
,
any
>
[];
private
focusNavigationFilter
:
((
node
:
ITreeNode
<
T
,
TFilterData
>
)
=>
boolean
)
|
undefined
;
protected
model
:
ITreeModel
<
T
,
TFilterData
,
TRef
>
;
...
...
@@ -884,7 +924,7 @@ export abstract class AbstractTree<T, TFilterData, TRef> implements IDisposable
this
.
disposables
.
push
(
filter
);
}
this
.
view
=
new
TreeNodeList
(
container
,
treeDelegate
,
this
.
renderers
,
this
.
focus
,
this
.
selection
,
asListOptions
(()
=>
this
.
model
,
_options
)
);
this
.
view
=
new
TreeNodeList
(
container
,
treeDelegate
,
this
.
renderers
,
this
.
focus
,
this
.
selection
,
{
...
asListOptions
(()
=>
this
.
model
,
_options
),
tree
:
this
}
);
this
.
model
=
this
.
createModel
(
this
.
view
,
_options
);
onDidChangeCollapseStateRelay
.
input
=
this
.
model
.
onDidChangeCollapseState
;
...
...
@@ -920,9 +960,6 @@ export abstract class AbstractTree<T, TFilterData, TRef> implements IDisposable
},
null
,
this
.
disposables
);
}
this
.
view
.
onTap
(
this
.
reactOnMouseClick
,
this
,
this
.
disposables
);
this
.
view
.
onMouseClick
(
this
.
reactOnMouseClick
,
this
,
this
.
disposables
);
if
(
_options
.
keyboardSupport
!==
false
)
{
const
onKeyDown
=
Event
.
chain
(
this
.
view
.
onKeyDown
)
.
filter
(
e
=>
!
isInputElement
(
e
.
target
as
HTMLElement
))
...
...
@@ -1164,27 +1201,6 @@ export abstract class AbstractTree<T, TFilterData, TRef> implements IDisposable
return
this
.
view
.
length
;
}
private
reactOnMouseClick
(
e
:
IListMouseEvent
<
ITreeNode
<
T
,
TFilterData
>>
):
void
{
const
node
=
e
.
element
;
if
(
!
node
)
{
return
;
}
if
(
this
.
view
.
multipleSelectionController
.
isSelectionRangeChangeEvent
(
e
)
||
this
.
view
.
multipleSelectionController
.
isSelectionSingleChangeEvent
(
e
))
{
return
;
}
if
(
!
this
.
openOnSingleClick
&&
e
.
browserEvent
.
detail
!==
2
)
{
return
;
}
const
location
=
this
.
model
.
getNodeLocation
(
node
);
const
recursive
=
e
.
browserEvent
.
altKey
;
this
.
model
.
setCollapsed
(
location
,
undefined
,
recursive
);
}
private
onLeftArrow
(
e
:
StandardKeyboardEvent
):
void
{
e
.
preventDefault
();
e
.
stopPropagation
();
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录