Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
c5e4b5f4
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,发现更多精彩内容 >>
提交
c5e4b5f4
编写于
4月 20, 2018
作者:
R
Rob Lourens
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Settings search in GUI - #3355
上级
a10799a6
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
195 addition
and
20 deletion
+195
-20
src/vs/workbench/parts/preferences/browser/settingsEditor2.ts
...vs/workbench/parts/preferences/browser/settingsEditor2.ts
+195
-20
未找到文件。
src/vs/workbench/parts/preferences/browser/settingsEditor2.ts
浏览文件 @
c5e4b5f4
...
...
@@ -11,7 +11,7 @@ import { IDelegate, IRenderer } from 'vs/base/browser/ui/list/list';
import
{
List
}
from
'
vs/base/browser/ui/list/listWidget
'
;
import
{
SelectBox
}
from
'
vs/base/browser/ui/selectBox/selectBox
'
;
import
{
IAction
}
from
'
vs/base/common/actions
'
;
import
{
Delayer
}
from
'
vs/base/common/async
'
;
import
{
Delayer
,
ThrottledDelayer
}
from
'
vs/base/common/async
'
;
import
{
Color
}
from
'
vs/base/common/color
'
;
import
{
Emitter
,
Event
}
from
'
vs/base/common/event
'
;
import
{
KeyCode
}
from
'
vs/base/common/keyCodes
'
;
...
...
@@ -30,11 +30,14 @@ import { IThemeService } from 'vs/platform/theme/common/themeService';
import
{
BaseEditor
}
from
'
vs/workbench/browser/parts/editor/baseEditor
'
;
import
{
EditorOptions
}
from
'
vs/workbench/common/editor
'
;
import
{
SearchWidget
,
SettingsTargetsWidget
}
from
'
vs/workbench/parts/preferences/browser/preferencesWidgets
'
;
import
{
IPreferencesService
,
ISetting
}
from
'
vs/workbench/services/preferences/common/preferences
'
;
import
{
IPreferencesService
,
ISetting
,
ISettingsEditorModel
,
ISearchResult
}
from
'
vs/workbench/services/preferences/common/preferences
'
;
import
{
PreferencesEditorInput2
}
from
'
vs/workbench/services/preferences/common/preferencesEditorInput
'
;
import
{
DefaultSettingsEditorModel
}
from
'
vs/workbench/services/preferences/common/preferencesModels
'
;
import
{
Button
}
from
'
vs/base/browser/ui/button/button
'
;
import
{
SettingMatches
}
from
'
vs/workbench/parts/preferences/electron-browser/preferencesSearch
'
;
import
{
IPreferencesSearchService
,
ISearchProvider
}
from
'
../common/preferences
'
;
import
{
IProgressService
}
from
'
vs/platform/progress/common/progress
'
;
import
{
isPromiseCanceledError
,
getErrorMessage
}
from
'
vs/base/common/errors
'
;
import
{
ILogService
}
from
'
vs/platform/log/common/log
'
;
const
SETTINGS_ENTRY_TEMPLATE_ID
=
'
settings.entry.template
'
;
const
SETTINGS_NAV_TEMPLATE_ID
=
'
settings.nav.template
'
;
...
...
@@ -64,6 +67,11 @@ interface IGroupTitleEntry extends IListEntry {
title
:
string
;
}
enum
SearchResultIdx
{
Local
=
0
,
Remote
=
1
}
let
$
=
DOM
.
$
;
export
class
SettingsEditor2
extends
BaseEditor
{
...
...
@@ -83,19 +91,33 @@ export class SettingsEditor2 extends BaseEditor {
private
settingsList
:
List
<
IListEntry
>
;
private
dimension
:
DOM
.
Dimension
;
private
delayedFiltering
:
Delayer
<
void
>
;
private
searchFocusContextKey
:
IContextKey
<
boolean
>
;
private
delayedFilterLogging
:
Delayer
<
void
>
;
private
localSearchDelayer
:
Delayer
<
void
>
;
private
remoteSearchThrottle
:
ThrottledDelayer
<
void
>
;
private
currentLocalSearchProvider
:
ISearchProvider
;
private
currentRemoteSearchProvider
:
ISearchProvider
;
private
searchResults
:
ISearchResult
[]
=
[];
constructor
(
@
ITelemetryService
telemetryService
:
ITelemetryService
,
@
IConfigurationService
private
configurationService
:
IConfigurationService
,
@
IThemeService
themeService
:
IThemeService
,
@
IContextMenuService
contextMenuService
:
IContextMenuService
,
@
IPreferencesService
private
preferencesService
:
IPreferencesService
,
@
IInstantiationService
private
instantiationService
:
IInstantiationService
@
IInstantiationService
private
instantiationService
:
IInstantiationService
,
@
IPreferencesSearchService
private
preferencesSearchService
:
IPreferencesSearchService
,
@
IProgressService
private
progressService
:
IProgressService
,
@
ILogService
private
logService
:
ILogService
)
{
super
(
SettingsEditor2
.
ID
,
telemetryService
,
themeService
);
this
.
delayedFiltering
=
new
Delayer
<
void
>
(
300
);
this
.
delayedFilterLogging
=
new
Delayer
<
void
>
(
1000
);
this
.
localSearchDelayer
=
new
Delayer
(
100
);
this
.
remoteSearchThrottle
=
new
ThrottledDelayer
(
200
);
this
.
_register
(
configurationService
.
onDidChangeConfiguration
(()
=>
this
.
render
()));
}
...
...
@@ -154,7 +176,7 @@ export class SettingsEditor2 extends BaseEditor {
placeholder
:
localize
(
'
SearchSettings.Placeholder
'
,
"
Search settings
"
),
focusKey
:
this
.
searchFocusContextKey
}));
this
.
_register
(
this
.
searchWidget
.
onDidChange
(
searchValue
=>
this
.
delayedFiltering
.
trigger
(()
=>
this
.
filterSettings
()
)));
this
.
_register
(
this
.
searchWidget
.
onDidChange
(
()
=>
this
.
onInputChanged
(
)));
const
headerControlsContainer
=
DOM
.
append
(
this
.
headerContainer
,
$
(
'
div.settings-header-controls-container
'
));
const
targetWidgetContainer
=
DOM
.
append
(
headerControlsContainer
,
$
(
'
.settings-target-container
'
));
...
...
@@ -268,19 +290,176 @@ export class SettingsEditor2 extends BaseEditor {
return
TPromise
.
as
(
null
);
}
private
filterSettings
():
void
{
this
.
renderEntries
();
private
onInputChanged
():
void
{
const
query
=
this
.
searchWidget
.
getValue
().
trim
();
this
.
delayedFilterLogging
.
cancel
();
this
.
triggerSearch
(
query
)
.
then
(()
=>
{
// const result = this.preferencesRenderers.lastFilterResult;
// if (result) {
// this.delayedFilterLogging.trigger(() => this.reportFilteringUsed(
// query,
// this.preferencesRenderers.lastFilterResult));
// }
});
}
private
triggerSearch
(
query
:
string
):
TPromise
<
void
>
{
if
(
query
)
{
return
TPromise
.
join
([
this
.
localSearchDelayer
.
trigger
(()
=>
this
.
localFilterPreferences
(
query
)),
this
.
remoteSearchThrottle
.
trigger
(()
=>
this
.
progressService
.
showWhile
(
this
.
remoteSearchPreferences
(
query
),
500
))
])
as
TPromise
;
}
else
{
// When clearing the input, update immediately to clear it
this
.
localSearchDelayer
.
cancel
();
// this.preferencesRenderers.localFilterPreferences(query);
this
.
remoteSearchThrottle
.
cancel
();
// return this.preferencesRenderers.remoteSearchPreferences(query);
this
.
searchResults
=
[];
this
.
renderEntries
();
return
TPromise
.
wrap
(
null
);
}
}
private
localFilterPreferences
(
query
:
string
):
TPromise
<
void
>
{
this
.
currentLocalSearchProvider
=
this
.
preferencesSearchService
.
getLocalSearchProvider
(
query
);
return
this
.
filterOrSearchPreferences
(
query
,
SearchResultIdx
.
Local
,
this
.
currentLocalSearchProvider
);
}
private
remoteSearchPreferences
(
query
:
string
):
TPromise
<
void
>
{
this
.
currentRemoteSearchProvider
=
this
.
preferencesSearchService
.
getRemoteSearchProvider
(
query
);
return
this
.
filterOrSearchPreferences
(
query
,
SearchResultIdx
.
Remote
,
this
.
currentRemoteSearchProvider
);
}
private
filterOrSearchPreferences
(
query
:
string
,
type
:
SearchResultIdx
,
searchProvider
:
ISearchProvider
):
TPromise
<
void
>
{
// this.lastQuery = query;
const
filterPs
:
TPromise
<
ISearchResult
>
[]
=
[
this
.
_filterOrSearchPreferencesModel
(
query
,
this
.
defaultSettingsEditorModel
,
searchProvider
)];
// filterPs.push(this.searchAllSettingsTargets(query, searchProvider));
return
TPromise
.
join
(
filterPs
).
then
(
results
=>
{
const
[
result
]
=
results
;
this
.
searchResults
[
type
]
=
result
;
this
.
renderSearchResults
(
this
.
searchResults
);
});
}
// private searchAllSettingsTargets(query: string, searchProvider: ISearchProvider): TPromise<void> {
// const searchPs = [
// this.searchSettingsTarget(query, searchProvider, ConfigurationTarget.WORKSPACE),
// this.searchSettingsTarget(query, searchProvider, ConfigurationTarget.USER)
// ];
// for (const folder of this.workspaceContextService.getWorkspace().folders) {
// const folderSettingsResource = this.preferencesService.getFolderSettingsResource(folder.uri);
// searchPs.push(this.searchSettingsTarget(query, searchProvider, folderSettingsResource));
// }
// return TPromise.join(searchPs).then(() => { });
// }
// private searchSettingsTarget(query: string, provider: ISearchProvider, target: SettingsTarget): TPromise<void> {
// if (!query) {
// // Don't open the other settings targets when query is empty
// this._onDidFilterResultsCountChange.fire({ target, count: 0 });
// return TPromise.wrap(null);
// }
// return this.getPreferencesEditorModel(target).then(model => {
// return model && this._filterOrSearchPreferencesModel('', <ISettingsEditorModel>model, provider);
// }).then(result => {
// const count = result ? this._flatten(result.filteredGroups).length : 0;
// this._onDidFilterResultsCountChange.fire({ target, count });
// }, err => {
// if (!isPromiseCanceledError(err)) {
// return TPromise.wrapError(err);
// }
// return null;
// });
// }
private
_filterOrSearchPreferencesModel
(
filter
:
string
,
model
:
ISettingsEditorModel
,
provider
:
ISearchProvider
):
TPromise
<
ISearchResult
>
{
const
searchP
=
provider
?
provider
.
searchModel
(
model
)
:
TPromise
.
wrap
(
null
);
return
searchP
.
then
<
ISearchResult
>
(
null
,
err
=>
{
if
(
isPromiseCanceledError
(
err
))
{
return
TPromise
.
wrapError
(
err
);
}
else
{
/* __GDPR__
"defaultSettings.searchError" : {
"message": { "classification": "CallstackOrException", "purpose": "FeatureInsight" },
"filter": { "classification": "SystemMetaData", "purpose": "FeatureInsight" }
}
*/
const
message
=
getErrorMessage
(
err
).
trim
();
if
(
message
&&
message
!==
'
Error
'
)
{
// "Error" = any generic network error
this
.
telemetryService
.
publicLog
(
'
defaultSettings.searchError
'
,
{
message
,
filter
});
this
.
logService
.
info
(
'
Setting search error:
'
+
message
);
}
return
null
;
}
});
}
// private async getPreferencesEditorModel(target: SettingsTarget): TPromise<ISettingsEditorModel | null> {
// const resource = target === ConfigurationTarget.USER ? this.preferencesService.userSettingsResource :
// target === ConfigurationTarget.WORKSPACE ? this.preferencesService.workspaceSettingsResource :
// target;
// if (!resource) {
// return null;
// }
// const targetKey = resource.toString();
// if (!this._prefsModelsForSearch.has(targetKey)) {
// try {
// const model = this._register(await this.preferencesService.createPreferencesEditorModel(resource));
// this._prefsModelsForSearch.set(targetKey, <ISettingsEditorModel>model);
// } catch (e) {
// // Will throw when the settings file doesn't exist.
// return null;
// }
// }
// return this._prefsModelsForSearch.get(targetKey);
// }
private
renderSearchResults
(
searchResults
:
ISearchResult
[]):
void
{
const
entries
:
ISettingItemEntry
[]
=
[];
const
seenSettings
=
new
Set
<
string
>
();
for
(
let
result
of
searchResults
)
{
if
(
!
result
)
{
continue
;
}
for
(
let
match
of
result
.
filterMatches
)
{
if
(
!
seenSettings
.
has
(
match
.
setting
.
key
))
{
const
entry
=
this
.
settingToEntry
(
match
.
setting
);
if
(
!
this
.
showConfiguredSettingsOnly
||
entry
.
isConfigured
)
{
seenSettings
.
add
(
entry
.
key
);
entries
.
push
(
entry
);
}
}
}
}
this
.
settingsList
.
splice
(
0
,
this
.
settingsList
.
length
,
entries
);
}
private
renderEntries
():
void
{
if
(
this
.
defaultSettingsEditorModel
)
{
const
filter
=
this
.
searchWidget
.
getValue
();
const
entries
:
(
ISettingItemEntry
|
IGroupTitleEntry
)[]
=
[];
const
entries
:
(
ISettingItemEntry
|
IGroupTitleEntry
)[]
=
[];
const
navEntries
:
INavListEntry
[]
=
[];
for
(
let
groupIdx
=
0
;
groupIdx
<
this
.
defaultSettingsEditorModel
.
settingsGroups
.
length
;
groupIdx
++
)
{
if
(
groupIdx
>
0
&&
!
(
this
.
showAllSettings
||
filter
))
{
if
(
groupIdx
>
0
&&
!
(
this
.
showAllSettings
))
{
break
;
}
...
...
@@ -288,13 +467,9 @@ export class SettingsEditor2 extends BaseEditor {
const
groupEntries
=
[];
for
(
const
section
of
group
.
sections
)
{
for
(
const
setting
of
section
.
settings
)
{
const
matches
=
new
SettingMatches
(
filter
,
setting
,
true
,
true
,
(
filter
,
setting
)
=>
this
.
defaultSettingsEditorModel
.
findValueMatches
(
filter
,
setting
)).
matches
;
if
(
matches
&&
matches
.
length
)
{
const
entry
=
this
.
settingToEntry
(
setting
);
if
(
!
this
.
showConfiguredSettingsOnly
||
(
this
.
showConfiguredSettingsOnly
&&
entry
.
isConfigured
))
{
groupEntries
.
push
(
entry
);
}
const
entry
=
this
.
settingToEntry
(
setting
);
if
(
!
this
.
showConfiguredSettingsOnly
||
(
this
.
showConfiguredSettingsOnly
&&
entry
.
isConfigured
))
{
groupEntries
.
push
(
entry
);
}
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录