Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
d6958430
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,发现更多精彩内容 >>
提交
d6958430
编写于
6月 14, 2018
作者:
R
Rob Lourens
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Settings editor - Make TOC and settings tree share a model and filter on 'show modified only'
上级
ddf9af90
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
16 addition
and
42 deletion
+16
-42
src/vs/workbench/parts/preferences/browser/settingsEditor2.ts
...vs/workbench/parts/preferences/browser/settingsEditor2.ts
+6
-4
src/vs/workbench/parts/preferences/browser/tocTree.ts
src/vs/workbench/parts/preferences/browser/tocTree.ts
+10
-38
未找到文件。
src/vs/workbench/parts/preferences/browser/settingsEditor2.ts
浏览文件 @
d6958430
...
...
@@ -31,7 +31,7 @@ import { EditorOptions, IEditor } from 'vs/workbench/common/editor';
import
{
SearchWidget
,
SettingsTarget
,
SettingsTargetsWidget
}
from
'
vs/workbench/parts/preferences/browser/preferencesWidgets
'
;
import
{
tocData
}
from
'
vs/workbench/parts/preferences/browser/settingsLayout
'
;
import
{
ISettingsEditorViewState
,
SearchResultIdx
,
SearchResultModel
,
SettingsAccessibilityProvider
,
SettingsDataSource
,
SettingsRenderer
,
SettingsTreeController
,
SettingsTreeElement
,
SettingsTreeFilter
,
SettingsTreeModel
}
from
'
vs/workbench/parts/preferences/browser/settingsTree
'
;
import
{
getTOCElement
,
TOCDataSource
,
TOCRenderer
}
from
'
vs/workbench/parts/preferences/browser/tocTree
'
;
import
{
TOCDataSource
,
TOCRenderer
}
from
'
vs/workbench/parts/preferences/browser/tocTree
'
;
import
{
CONTEXT_SETTINGS_EDITOR
,
CONTEXT_SETTINGS_SEARCH_FOCUS
,
IPreferencesSearchService
,
ISearchProvider
}
from
'
vs/workbench/parts/preferences/common/preferences
'
;
import
{
IPreferencesService
,
ISearchResult
,
ISettingsEditorModel
}
from
'
vs/workbench/services/preferences/common/preferences
'
;
import
{
SettingsEditor2Input
}
from
'
vs/workbench/services/preferences/common/preferencesEditorInput
'
;
...
...
@@ -231,7 +231,8 @@ export class SettingsEditor2 extends BaseEditor {
this
.
tocTree
=
this
.
instantiationService
.
createInstance
(
WorkbenchTree
,
this
.
tocTreeContainer
,
<
ITreeConfiguration
>
{
dataSource
:
tocTreeDataSource
,
renderer
renderer
,
filter
:
this
.
instantiationService
.
createInstance
(
SettingsTreeFilter
,
this
.
viewState
)
},
{
showLoading
:
false
...
...
@@ -328,6 +329,8 @@ export class SettingsEditor2 extends BaseEditor {
private
onShowConfiguredOnlyClicked
():
void
{
this
.
viewState
.
showConfiguredOnly
=
this
.
showConfiguredSettingsOnlyCheckbox
.
checked
;
this
.
refreshTreeAndMaintainFocus
();
this
.
tocTree
.
refresh
();
this
.
settingsTree
.
setScrollPosition
(
0
);
this
.
expandAll
(
this
.
settingsTree
);
}
...
...
@@ -427,9 +430,8 @@ export class SettingsEditor2 extends BaseEditor {
}
this
.
defaultSettingsEditorModel
=
model
;
this
.
tocTree
.
setInput
(
getTOCElement
(
tocData
));
this
.
settingsTreeModel
=
this
.
instantiationService
.
createInstance
(
SettingsTreeModel
,
this
.
viewState
,
tocData
,
this
.
defaultSettingsEditorModel
.
settingsGroups
.
slice
(
1
));
this
.
tocTree
.
setInput
(
this
.
settingsTreeModel
.
root
);
this
.
settingsTree
.
setInput
(
this
.
settingsTreeModel
.
root
);
});
}
...
...
src/vs/workbench/parts/preferences/browser/tocTree.ts
浏览文件 @
d6958430
...
...
@@ -6,52 +6,24 @@
import
*
as
DOM
from
'
vs/base/browser/dom
'
;
import
{
TPromise
}
from
'
vs/base/common/winjs.base
'
;
import
{
IDataSource
,
IRenderer
,
ITree
}
from
'
vs/base/parts/tree/browser/tree
'
;
import
{
ISetting
}
from
'
vs/workbench/services/preferences/common/preferences
'
;
import
{
SettingsTreeElement
,
SettingsTreeGroupElement
}
from
'
vs/workbench/parts/preferences/browser/settingsTree
'
;
const
$
=
DOM
.
$
;
export
interface
ITOCEntry
{
id
:
string
;
label
:
string
;
children
?:
ITOCEntry
[];
settings
?:
(
string
|
ISetting
)[];
}
export
class
TOCElement
{
id
:
string
;
label
:
string
;
parent
?:
TOCElement
;
children
?:
TOCElement
[];
}
export
function
getTOCElement
(
tocRoot
:
ITOCEntry
,
parent
?:
TOCElement
):
TOCElement
{
const
element
=
new
TOCElement
();
element
.
id
=
tocRoot
.
id
;
element
.
label
=
tocRoot
.
label
;
element
.
parent
=
parent
;
if
(
tocRoot
.
children
)
{
element
.
children
=
tocRoot
.
children
.
map
(
child
=>
getTOCElement
(
child
,
element
));
}
return
element
;
}
export
class
TOCDataSource
implements
IDataSource
{
getId
(
tree
:
ITree
,
element
:
TOC
Element
):
string
{
getId
(
tree
:
ITree
,
element
:
SettingsTreeGroup
Element
):
string
{
return
element
.
id
;
}
hasChildren
(
tree
:
ITree
,
element
:
TOC
Element
):
boolean
{
return
!!
(
element
.
children
&&
element
.
children
.
length
);
hasChildren
(
tree
:
ITree
,
element
:
SettingsTree
Element
):
boolean
{
return
element
instanceof
SettingsTreeGroupElement
&&
element
.
children
&&
element
.
children
.
every
(
child
=>
child
instanceof
SettingsTreeGroupElement
);
}
getChildren
(
tree
:
ITree
,
element
:
TOCElement
):
TPromise
<
TOC
Element
[],
any
>
{
return
TPromise
.
as
(
<
TOC
Element
[]
>
element
.
children
);
getChildren
(
tree
:
ITree
,
element
:
SettingsTreeGroupElement
):
TPromise
<
SettingsTree
Element
[],
any
>
{
return
TPromise
.
as
(
<
SettingsTree
Element
[]
>
element
.
children
);
}
getParent
(
tree
:
ITree
,
element
:
TOC
Element
):
TPromise
<
any
,
any
>
{
getParent
(
tree
:
ITree
,
element
:
SettingsTree
Element
):
TPromise
<
any
,
any
>
{
return
TPromise
.
wrap
(
element
.
parent
);
}
...
...
@@ -67,11 +39,11 @@ interface ITOCEntryTemplate {
}
export
class
TOCRenderer
implements
IRenderer
{
getHeight
(
tree
:
ITree
,
element
:
TOC
Element
):
number
{
getHeight
(
tree
:
ITree
,
element
:
SettingsTree
Element
):
number
{
return
22
;
}
getTemplateId
(
tree
:
ITree
,
element
:
TOC
Element
):
string
{
getTemplateId
(
tree
:
ITree
,
element
:
SettingsTree
Element
):
string
{
return
TOC_ENTRY_TEMPLATE_ID
;
}
...
...
@@ -81,7 +53,7 @@ export class TOCRenderer implements IRenderer {
};
}
renderElement
(
tree
:
ITree
,
element
:
TOC
Element
,
templateId
:
string
,
template
:
ITOCEntryTemplate
):
void
{
renderElement
(
tree
:
ITree
,
element
:
SettingsTreeGroup
Element
,
templateId
:
string
,
template
:
ITOCEntryTemplate
):
void
{
template
.
element
.
textContent
=
element
.
label
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录