Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
a05a4fde
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,发现更多精彩内容 >>
提交
a05a4fde
编写于
11月 25, 2015
作者:
J
Joao Moreno
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'master' of
https://github.com/akamud/vscode
into akamud-master
上级
aba9d6bf
418a76fa
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
110 addition
and
1 deletion
+110
-1
src/vs/workbench/parts/extensions/electron-browser/extensionsActions.ts
...ch/parts/extensions/electron-browser/extensionsActions.ts
+23
-0
src/vs/workbench/parts/extensions/electron-browser/extensionsQuickOpen.ts
.../parts/extensions/electron-browser/extensionsQuickOpen.ts
+74
-0
src/vs/workbench/parts/extensions/electron-browser/extensionsWorkbenchExtension.ts
...tensions/electron-browser/extensionsWorkbenchExtension.ts
+13
-1
未找到文件。
src/vs/workbench/parts/extensions/electron-browser/extensionsActions.ts
浏览文件 @
a05a4fde
...
...
@@ -54,3 +54,26 @@ export class InstallExtensionAction extends Action {
return
true
;
}
}
export
class
ListExtensionsUpdatesAction
extends
Action
{
static
ID
=
'
workbench.extensions.action.listExtensionsUpdates
'
;
static
LABEL
=
nls
.
localize
(
'
showExtensionsUpdates
'
,
"
Show Extensions Updates
"
);
constructor
(
id
:
string
,
label
:
string
,
@
IExtensionsService
private
extensionsService
:
IExtensionsService
,
@
IQuickOpenService
private
quickOpenService
:
IQuickOpenService
)
{
super
(
id
,
label
,
null
,
true
);
}
public
run
():
Promise
{
return
this
.
quickOpenService
.
show
(
'
ext update
'
);
}
protected
isEnabled
():
boolean
{
return
true
;
}
}
src/vs/workbench/parts/extensions/electron-browser/extensionsQuickOpen.ts
浏览文件 @
a05a4fde
...
...
@@ -473,3 +473,77 @@ export class GalleryExtensionsHandler extends QuickOpenHandler {
return
{
autoFocusFirstEntry
:
true
};
}
}
class
ExtensionsUpdateModel
implements
IModel
<
IExtensionEntry
>
{
public
dataSource
=
new
DataSource
();
public
renderer
:
IRenderer
<
IExtensionEntry
>
;
public
runner
:
IRunner
<
IExtensionEntry
>
;
public
entries
:
IExtensionEntry
[];
constructor
(
private
galleryExtensions
:
IExtension
[],
private
localExtensions
:
IExtension
[],
@
IInstantiationService
instantiationService
:
IInstantiationService
)
{
this
.
renderer
=
instantiationService
.
createInstance
(
Renderer
);
this
.
runner
=
instantiationService
.
createInstance
(
InstallRunner
);
this
.
entries
=
[];
}
public
set
input
(
input
:
string
)
{
this
.
entries
=
this
.
galleryExtensions
.
map
(
extension
=>
({
extension
,
highlights
:
getHighlights
(
input
,
extension
)
}))
.
filter
(({
extension
,
highlights
})
=>
{
const
local
=
this
.
localExtensions
.
filter
(
local
=>
extensionEquals
(
local
,
extension
))[
0
];
return
local
&&
local
.
version
<
extension
.
version
&&
!!
highlights
;
})
.
map
(({
extension
,
highlights
}:
{
extension
:
IExtension
,
highlights
:
IHighlights
})
=>
{
return
{
extension
,
highlights
,
state
:
ExtensionState
.
Outdated
};
})
.
sort
((
a
,
b
)
=>
a
.
extension
.
name
.
localeCompare
(
b
.
extension
.
name
));
}
}
export
class
ExtensionsUpdateHandler
extends
QuickOpenHandler
{
private
modelPromise
:
TPromise
<
ExtensionsUpdateModel
>
;
constructor
(
@
IInstantiationService
private
instantiationService
:
IInstantiationService
,
@
IExtensionsService
private
extensionsService
:
IExtensionsService
,
@
IGalleryService
private
galleryService
:
IGalleryService
,
@
ITelemetryService
private
telemetryService
:
ITelemetryService
)
{
super
();
}
getResults
(
input
:
string
):
TPromise
<
IModel
<
IExtensionEntry
>>
{
if
(
!
this
.
modelPromise
)
{
this
.
telemetryService
.
publicLog
(
'
extensionGallery:open
'
);
this
.
modelPromise
=
TPromise
.
join
<
any
>
([
this
.
galleryService
.
query
(),
this
.
extensionsService
.
getInstalled
()])
.
then
(
result
=>
this
.
instantiationService
.
createInstance
(
ExtensionsUpdateModel
,
result
[
0
],
result
[
1
]));
}
return
this
.
modelPromise
.
then
(
model
=>
{
model
.
input
=
input
;
return
model
;
});
}
onClose
(
canceled
:
boolean
):
void
{
this
.
modelPromise
=
null
;
}
getEmptyLabel
(
input
:
string
):
string
{
return
nls
.
localize
(
'
noOutdatedExtensions
'
,
"
No outdated extensions found
"
);
}
getAutoFocus
(
searchValue
:
string
):
IAutoFocus
{
return
{
autoFocusFirstEntry
:
true
};
}
}
\ No newline at end of file
src/vs/workbench/parts/extensions/electron-browser/extensionsWorkbenchExtension.ts
浏览文件 @
a05a4fde
...
...
@@ -16,7 +16,7 @@ import { IWorkspaceContextService } from 'vs/workbench/services/workspace/common
import
{
ReloadWindowAction
}
from
'
vs/workbench/electron-browser/actions
'
;
import
wbaregistry
=
require
(
'
vs/workbench/browser/actionRegistry
'
);
import
{
SyncActionDescriptor
}
from
'
vs/platform/actions/common/actions
'
;
import
{
ListExtensionsAction
,
InstallExtensionAction
}
from
'
./extensionsActions
'
;
import
{
ListExtensionsAction
,
InstallExtensionAction
,
ListExtensionsUpdatesAction
}
from
'
./extensionsActions
'
;
import
{
IQuickOpenRegistry
,
Extensions
,
QuickOpenHandlerDescriptor
}
from
'
vs/workbench/browser/quickopen
'
;
import
ipc
=
require
(
'
ipc
'
);
...
...
@@ -67,6 +67,18 @@ export class ExtensionsWorkbenchExtension implements IWorkbenchContribution {
true
)
);
actionRegistry
.
registerWorkbenchAction
(
new
SyncActionDescriptor
(
ListExtensionsUpdatesAction
,
ListExtensionsUpdatesAction
.
ID
,
ListExtensionsUpdatesAction
.
LABEL
),
extensionsCategory
);
(
<
IQuickOpenRegistry
>
platform
.
Registry
.
as
(
Extensions
.
Quickopen
)).
registerQuickOpenHandler
(
new
QuickOpenHandlerDescriptor
(
'
vs/workbench/parts/extensions/electron-browser/extensionsQuickOpen
'
,
'
ExtensionsUpdateHandler
'
,
'
ext update
'
,
nls
.
localize
(
'
extensionsUpdateCommands
'
,
"
Extensions Update Commands
"
),
true
)
);
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录