Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
4728d11f
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,发现更多精彩内容 >>
提交
4728d11f
编写于
10月 11, 2018
作者:
J
Joao Moreno
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
markers panel: finally mouse and keyboard navigation
very very hacky
上级
afe13242
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
112 addition
and
31 deletion
+112
-31
src/vs/base/browser/ui/tree/abstractTree.ts
src/vs/base/browser/ui/tree/abstractTree.ts
+10
-13
src/vs/platform/list/browser/listService.ts
src/vs/platform/list/browser/listService.ts
+95
-12
src/vs/workbench/parts/markers/electron-browser/markersPanel.ts
.../workbench/parts/markers/electron-browser/markersPanel.ts
+5
-5
src/vs/workbench/parts/markers/electron-browser/markersTreeController.ts
...h/parts/markers/electron-browser/markersTreeController.ts
+2
-1
未找到文件。
src/vs/base/browser/ui/tree/abstractTree.ts
浏览文件 @
4728d11f
...
...
@@ -6,15 +6,14 @@
import
'
vs/css!./tree
'
;
import
{
IDisposable
,
dispose
}
from
'
vs/base/common/lifecycle
'
;
import
{
IListOptions
,
List
,
IIdentityProvider
,
IMultipleSelectionController
,
IListStyles
}
from
'
vs/base/browser/ui/list/listWidget
'
;
import
{
IVirtualDelegate
,
IRenderer
,
IListMouseEvent
}
from
'
vs/base/browser/ui/list/list
'
;
import
{
IVirtualDelegate
,
IRenderer
,
IListMouseEvent
,
IListEvent
}
from
'
vs/base/browser/ui/list/list
'
;
import
{
append
,
$
}
from
'
vs/base/browser/dom
'
;
import
{
Event
,
Relay
,
chain
,
mapEvent
}
from
'
vs/base/common/event
'
;
import
{
Event
,
Relay
,
chain
}
from
'
vs/base/common/event
'
;
import
{
StandardKeyboardEvent
}
from
'
vs/base/browser/keyboardEvent
'
;
import
{
KeyCode
}
from
'
vs/base/common/keyCodes
'
;
import
{
ITreeModel
,
ITreeNode
,
ITreeRenderer
}
from
'
vs/base/browser/ui/tree/tree
'
;
import
{
ISpliceable
}
from
'
vs/base/common/sequence
'
;
import
{
IIndexTreeModelOptions
}
from
'
vs/base/browser/ui/tree/indexTreeModel
'
;
import
{
memoize
}
from
'
vs/base/common/decorators
'
;
export
function
createComposedTreeListOptions
<
T
,
N
extends
{
element
:
T
}
>
(
options
?:
IListOptions
<
T
>
):
IListOptions
<
N
>
{
if
(
!
options
)
{
...
...
@@ -161,6 +160,7 @@ function isInputElement(e: HTMLElement): boolean {
}
export
interface
ITreeOptions
<
T
,
TFilterData
=
void
>
extends
IListOptions
<
T
>
,
IIndexTreeModelOptions
<
T
,
TFilterData
>
{
}
export
interface
ITreeEvent
<
T
,
TFilterData
>
extends
IListEvent
<
ITreeNode
<
T
,
TFilterData
>>
{
}
export
abstract
class
AbstractTree
<
T
,
TFilterData
,
TRef
>
implements
IDisposable
{
...
...
@@ -170,14 +170,8 @@ export abstract class AbstractTree<T, TFilterData, TRef> implements IDisposable
readonly
onDidChangeCollapseState
:
Event
<
ITreeNode
<
T
,
TFilterData
>>
;
readonly
onDidChangeRenderNodeCount
:
Event
<
ITreeNode
<
T
,
TFilterData
>>
;
@
memoize
get
onDidChangeFocus
():
Event
<
T
[]
>
{
return
mapEvent
(
this
.
view
.
onFocusChange
,
e
=>
e
.
elements
.
map
(
e
=>
e
.
element
));
}
@
memoize
get
onDidChangeSelection
():
Event
<
T
[]
>
{
return
mapEvent
(
this
.
view
.
onSelectionChange
,
e
=>
e
.
elements
.
map
(
e
=>
e
.
element
));
}
readonly
onDidChangeFocus
:
Event
<
ITreeEvent
<
T
,
TFilterData
>>
;
readonly
onDidChangeSelection
:
Event
<
ITreeEvent
<
T
,
TFilterData
>>
;
get
onDidFocus
():
Event
<
void
>
{
return
this
.
view
.
onDidFocus
;
}
get
onDidBlur
():
Event
<
void
>
{
return
this
.
view
.
onDidBlur
;
}
...
...
@@ -196,6 +190,9 @@ export abstract class AbstractTree<T, TFilterData, TRef> implements IDisposable
this
.
disposables
.
push
(...
treeRenderers
);
this
.
view
=
new
List
(
container
,
treeDelegate
,
treeRenderers
,
createComposedTreeListOptions
<
T
,
ITreeNode
<
T
,
TFilterData
>>
(
options
));
this
.
onDidChangeFocus
=
this
.
view
.
onFocusChange
;
this
.
onDidChangeSelection
=
this
.
view
.
onSelectionChange
;
this
.
model
=
this
.
createModel
(
this
.
view
,
options
);
onDidChangeCollapseStateRelay
.
input
=
this
.
model
.
onDidChangeCollapseState
;
this
.
onDidChangeCollapseState
=
this
.
model
.
onDidChangeCollapseState
;
...
...
@@ -270,9 +267,9 @@ export abstract class AbstractTree<T, TFilterData, TRef> implements IDisposable
this
.
model
.
refilter
();
}
setSelection
(
elements
:
TRef
[]):
void
{
setSelection
(
elements
:
TRef
[]
,
browserEvent
?:
UIEvent
):
void
{
const
indexes
=
elements
.
map
(
e
=>
this
.
model
.
getListIndex
(
e
));
this
.
view
.
setSelection
(
indexes
);
this
.
view
.
setSelection
(
indexes
,
browserEvent
);
}
getSelection
():
T
[]
{
...
...
src/vs/platform/list/browser/listService.ts
浏览文件 @
4728d11f
...
...
@@ -33,7 +33,7 @@ import { attachInputBoxStyler, attachListStyler, computeStyles, defaultListStyle
import
{
IThemeService
}
from
'
vs/platform/theme/common/themeService
'
;
import
{
InputFocusedContextKey
}
from
'
vs/platform/workbench/common/contextkeys
'
;
import
{
ObjectTree
}
from
'
vs/base/browser/ui/tree/objectTree
'
;
import
{
ITreeOptions
as
ITreeOptions2
}
from
'
vs/base/browser/ui/tree/abstractTree
'
;
import
{
ITreeOptions
as
ITreeOptions2
,
ITreeEvent
}
from
'
vs/base/browser/ui/tree/abstractTree
'
;
import
{
ITreeRenderer
}
from
'
vs/base/browser/ui/tree/tree
'
;
export
type
ListWidget
=
List
<
any
>
|
PagedList
<
any
>
|
ITree
|
ObjectTree
<
any
,
any
>
;
...
...
@@ -565,6 +565,84 @@ export class TreeResourceNavigator extends Disposable {
}
}
export
interface
IOpenEvent
<
T
>
{
editorOptions
:
IEditorOptions
;
sideBySide
:
boolean
;
element
:
T
;
}
export
interface
IResourceResultsNavigationOptions
{
openOnFocus
:
boolean
;
}
export
class
ObjectTreeResourceNavigator
<
T
,
TFilterData
>
extends
Disposable
{
private
readonly
_openResource
:
Emitter
<
IOpenEvent
<
T
>>
=
new
Emitter
<
IOpenEvent
<
T
>>
();
readonly
openResource
:
Event
<
IOpenEvent
<
T
>>
=
this
.
_openResource
.
event
;
constructor
(
private
tree
:
WorkbenchObjectTree
<
T
,
TFilterData
>
,
private
options
?:
IResourceResultsNavigationOptions
)
{
super
();
this
.
registerListeners
();
}
private
registerListeners
():
void
{
if
(
this
.
options
&&
this
.
options
.
openOnFocus
)
{
this
.
_register
(
this
.
tree
.
onDidChangeFocus
(
e
=>
this
.
onFocus
(
e
)));
}
this
.
_register
(
this
.
tree
.
onDidChangeSelection
(
e
=>
this
.
onSelection
(
e
)));
}
private
onFocus
(
e
:
ITreeEvent
<
T
,
TFilterData
>
):
void
{
const
focus
=
this
.
tree
.
getFocus
();
this
.
tree
.
setSelection
(
focus
,
e
.
browserEvent
);
const
isMouseEvent
=
e
.
browserEvent
instanceof
MouseEvent
;
const
isDoubleClick
=
isMouseEvent
&&
e
.
browserEvent
&&
e
.
browserEvent
.
detail
===
2
;
if
(
!
isMouseEvent
||
this
.
tree
.
openOnSingleClick
||
isDoubleClick
)
{
this
.
_openResource
.
fire
({
editorOptions
:
{
preserveFocus
:
true
,
pinned
:
false
,
revealIfVisible
:
true
},
sideBySide
:
false
,
element
:
focus
[
0
]
});
}
}
private
onSelection
(
e
:
ITreeEvent
<
T
,
TFilterData
>
):
void
{
const
isMouseEvent
=
e
.
browserEvent
&&
e
.
browserEvent
instanceof
MouseEvent
;
if
(
!
isMouseEvent
||
this
.
tree
.
openOnSingleClick
)
{
return
;
}
const
isDoubleClick
=
isMouseEvent
&&
e
.
browserEvent
&&
e
.
browserEvent
.
detail
===
2
;
if
(
!
isMouseEvent
||
this
.
tree
.
openOnSingleClick
||
isDoubleClick
)
{
if
(
isDoubleClick
&&
e
.
browserEvent
)
{
e
.
browserEvent
.
preventDefault
();
// focus moves to editor, we need to prevent default
}
const
sideBySide
=
e
.
browserEvent
&&
e
.
browserEvent
instanceof
KeyboardEvent
&&
(
e
.
browserEvent
.
ctrlKey
||
e
.
browserEvent
.
metaKey
||
e
.
browserEvent
.
altKey
);
this
.
_openResource
.
fire
({
editorOptions
:
{
preserveFocus
:
isDoubleClick
,
pinned
:
isDoubleClick
,
revealIfVisible
:
true
},
sideBySide
,
element
:
this
.
tree
.
getSelection
()[
0
]
});
}
}
}
export
interface
IHighlighter
{
getHighlights
(
tree
:
ITree
,
element
:
any
,
pattern
:
string
):
FuzzyScore
;
getHighlightsStorageKey
?(
element
:
any
):
any
;
...
...
@@ -810,6 +888,7 @@ export class WorkbenchObjectTree<T extends NonNullable<any>, TFilterData = void>
private
hasDoubleSelection
:
IContextKey
<
boolean
>
;
private
hasMultiSelection
:
IContextKey
<
boolean
>
;
private
_openOnSingleClick
:
boolean
;
private
_useAltAsMultipleSelectionModifier
:
boolean
;
constructor
(
...
...
@@ -820,7 +899,7 @@ export class WorkbenchObjectTree<T extends NonNullable<any>, TFilterData = void>
@
IContextKeyService
contextKeyService
:
IContextKeyService
,
@
IListService
listService
:
IListService
,
@
IThemeService
themeService
:
IThemeService
,
@
IConfigurationService
private
configurationService
:
IConfigurationService
@
IConfigurationService
configurationService
:
IConfigurationService
)
{
super
(
container
,
delegate
,
renderers
,
{
keyboardSupport
:
false
,
...
...
@@ -839,9 +918,10 @@ export class WorkbenchObjectTree<T extends NonNullable<any>, TFilterData = void>
this
.
hasDoubleSelection
=
WorkbenchListDoubleSelection
.
bindTo
(
this
.
contextKeyService
);
this
.
hasMultiSelection
=
WorkbenchListMultiSelection
.
bindTo
(
this
.
contextKeyService
);
this
.
_openOnSingleClick
=
useSingleClickToOpen
(
configurationService
);
this
.
_useAltAsMultipleSelectionModifier
=
useAltAsMultipleSelectionModifier
(
configurationService
);
this
.
disposables
.
push
(
combinedDisposable
([
this
.
disposables
.
push
(
this
.
contextKeyService
,
(
listService
as
ListService
).
register
(
this
),
attachListStyler
(
this
,
themeService
),
...
...
@@ -858,18 +938,21 @@ export class WorkbenchObjectTree<T extends NonNullable<any>, TFilterData = void>
const
focus
=
this
.
getFocus
();
this
.
hasSelectionOrFocus
.
set
(
selection
.
length
>
0
||
focus
.
length
>
0
);
})
]));
}),
configurationService
.
onDidChangeConfiguration
(
e
=>
{
if
(
e
.
affectsConfiguration
(
openModeSettingKey
))
{
this
.
_openOnSingleClick
=
useSingleClickToOpen
(
configurationService
);
}
this
.
registerListeners
();
if
(
e
.
affectsConfiguration
(
multiSelectModifierSettingKey
))
{
this
.
_useAltAsMultipleSelectionModifier
=
useAltAsMultipleSelectionModifier
(
configurationService
);
}
})
);
}
private
registerListeners
():
void
{
this
.
disposables
.
push
(
this
.
configurationService
.
onDidChangeConfiguration
(
e
=>
{
if
(
e
.
affectsConfiguration
(
multiSelectModifierSettingKey
))
{
this
.
_useAltAsMultipleSelectionModifier
=
useAltAsMultipleSelectionModifier
(
this
.
configurationService
);
}
}));
get
openOnSingleClick
():
boolean
{
return
this
.
_openOnSingleClick
;
}
get
useAltAsMultipleSelectionModifier
():
boolean
{
...
...
src/vs/workbench/parts/markers/electron-browser/markersPanel.ts
浏览文件 @
4728d11f
...
...
@@ -30,7 +30,7 @@ import { IContextKey, IContextKeyService } from 'vs/platform/contextkey/common/c
import
{
Iterator
}
from
'
vs/base/common/iterator
'
;
import
{
ITreeElement
,
ITreeNode
}
from
'
vs/base/browser/ui/tree/tree
'
;
import
{
debounceEvent
,
Relay
}
from
'
vs/base/common/event
'
;
import
{
WorkbenchObjectTree
}
from
'
vs/platform/list/browser/listService
'
;
import
{
WorkbenchObjectTree
,
ObjectTreeResourceNavigator
}
from
'
vs/platform/list/browser/listService
'
;
import
{
FilterOptions
}
from
'
vs/workbench/parts/markers/electron-browser/markersFilterOptions
'
;
import
{
IExpression
,
getEmptyExpression
}
from
'
vs/base/common/glob
'
;
import
{
mixin
,
deepClone
}
from
'
vs/base/common/objects
'
;
...
...
@@ -325,10 +325,10 @@ export class MarkersPanel extends Panel {
// relatedInformationFocusContextKey.set(false);
// }));
// const markersNavigator = this._register(new
TreeResourceNavigator(this.tree, { openOnFocus: true }));
//
this._register(debounceEvent(markersNavigator.openResource, (last, event) => event, 75, true)(options => {
//
this.openFileAtElement(options.element, options.editorOptions.preserveFocus, options.sideBySide, options.editorOptions.pinned);
//
}));
const
markersNavigator
=
this
.
_register
(
new
Object
TreeResourceNavigator
(
this
.
tree
,
{
openOnFocus
:
true
}));
this
.
_register
(
debounceEvent
(
markersNavigator
.
openResource
,
(
last
,
event
)
=>
event
,
75
,
true
)(
options
=>
{
this
.
openFileAtElement
(
options
.
element
,
options
.
editorOptions
.
preserveFocus
,
options
.
sideBySide
,
options
.
editorOptions
.
pinned
);
}));
}
// TODO@joao
...
...
src/vs/workbench/parts/markers/electron-browser/markersTreeController.ts
浏览文件 @
4728d11f
...
...
@@ -61,8 +61,9 @@ export class Controller extends WorkbenchTreeController {
return
false
;
}
// TODO@Joao
public
onContextMenu
(
tree
:
WorkbenchTree
,
element
:
any
,
event
:
tree
.
ContextMenuEvent
):
boolean
{
tree
.
setFocus
(
element
,
{
preventOpenOnFocus
:
true
}
);
tree
.
setFocus
(
element
/* , { preventOpenOnFocus: true } */
);
const
anchor
=
{
x
:
event
.
posx
,
y
:
event
.
posy
};
this
.
contextMenuService
.
showContextMenu
({
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录