Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
徽霖
Vscode
提交
b4693045
V
Vscode
项目概览
徽霖
/
Vscode
通知
9
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,发现更多精彩内容 >>
提交
b4693045
编写于
8月 18, 2017
作者:
M
Matt Bierner
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Use async for releaseNotesEditor
上级
5bb04d68
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
38 addition
and
44 deletion
+38
-44
src/vs/workbench/parts/update/electron-browser/releaseNotesEditor.ts
...bench/parts/update/electron-browser/releaseNotesEditor.ts
+38
-44
未找到文件。
src/vs/workbench/parts/update/electron-browser/releaseNotesEditor.ts
浏览文件 @
b4693045
...
...
@@ -62,9 +62,9 @@ export class ReleaseNotesEditor extends WebviewEditor {
this
.
content
=
append
(
container
,
$
(
'
.release-notes
'
,
{
'
style
'
:
'
height: 100%; position: relative; overflow: hidden;
'
}));
}
setInput
(
input
:
ReleaseNotesInput
,
options
:
EditorOptions
):
TPromise
<
void
>
{
async
setInput
(
input
:
ReleaseNotesInput
,
options
:
EditorOptions
):
TPromise
<
void
>
{
if
(
this
.
input
&&
this
.
input
.
matches
(
input
))
{
return
TPromise
.
as
(
undefined
)
;
return
undefined
;
}
const
{
text
}
=
input
;
...
...
@@ -72,48 +72,42 @@ export class ReleaseNotesEditor extends WebviewEditor {
this
.
contentDisposables
=
dispose
(
this
.
contentDisposables
);
this
.
content
.
innerHTML
=
''
;
return
super
.
setInput
(
input
,
options
)
.
then
(()
=>
{
const
result
=
[];
const
renderer
=
new
marked
.
Renderer
();
renderer
.
code
=
(
code
,
lang
)
=>
{
const
modeId
=
this
.
modeService
.
getModeIdForLanguageName
(
lang
);
result
.
push
(
this
.
modeService
.
getOrCreateMode
(
modeId
));
return
''
;
};
marked
(
text
,
{
renderer
});
return
TPromise
.
join
(
result
);
}).
then
(()
=>
{
const
renderer
=
new
marked
.
Renderer
();
renderer
.
code
=
(
code
,
lang
)
=>
{
const
modeId
=
this
.
modeService
.
getModeIdForLanguageName
(
lang
);
return
`<code>
${
tokenizeToString
(
code
,
modeId
)}
</code>`
;
};
return
marked
(
text
,
{
renderer
});
})
.
then
(
renderBody
)
.
then
<
void
>
(
body
=>
{
this
.
_webview
=
new
WebView
(
this
.
content
,
this
.
partService
.
getContainer
(
Parts
.
EDITOR_PART
),
this
.
_contextViewService
,
this
.
contextKey
);
if
(
this
.
input
&&
this
.
input
instanceof
ReleaseNotesInput
)
{
const
state
=
this
.
loadViewState
(
this
.
input
.
version
);
if
(
state
)
{
this
.
_webview
.
initialScrollProgress
=
state
.
scrollYPercentage
;
}
}
this
.
onThemeChange
(
this
.
themeService
.
getTheme
());
this
.
_webview
.
contents
=
[
body
];
this
.
_webview
.
onDidClickLink
(
link
=>
this
.
openerService
.
open
(
link
),
null
,
this
.
contentDisposables
);
this
.
_webview
.
onDidScroll
(
event
=>
{
this
.
scrollYPercentage
=
event
.
scrollYPercentage
;
},
null
,
this
.
contentDisposables
);
this
.
themeService
.
onThemeChange
(
this
.
onThemeChange
,
this
,
this
.
contentDisposables
);
this
.
contentDisposables
.
push
(
this
.
_webview
);
this
.
contentDisposables
.
push
(
toDisposable
(()
=>
this
.
_webview
=
null
));
});
await
super
.
setInput
(
input
,
options
);
const
result
=
[];
const
renderer
=
new
marked
.
Renderer
();
renderer
.
code
=
(
code
,
lang
)
=>
{
const
modeId
=
this
.
modeService
.
getModeIdForLanguageName
(
lang
);
result
.
push
(
this
.
modeService
.
getOrCreateMode
(
modeId
));
return
''
;
};
marked
(
text
,
{
renderer
});
await
TPromise
.
join
(
result
);
renderer
.
code
=
(
code
,
lang
)
=>
{
const
modeId
=
this
.
modeService
.
getModeIdForLanguageName
(
lang
);
return
`<code>
${
tokenizeToString
(
code
,
modeId
)}
</code>`
;
};
const
body
=
renderBody
(
marked
(
text
,
{
renderer
}));
this
.
_webview
=
new
WebView
(
this
.
content
,
this
.
partService
.
getContainer
(
Parts
.
EDITOR_PART
),
this
.
_contextViewService
,
this
.
contextKey
);
if
(
this
.
input
&&
this
.
input
instanceof
ReleaseNotesInput
)
{
const
state
=
this
.
loadViewState
(
this
.
input
.
version
);
if
(
state
)
{
this
.
_webview
.
initialScrollProgress
=
state
.
scrollYPercentage
;
}
}
this
.
onThemeChange
(
this
.
themeService
.
getTheme
());
this
.
_webview
.
contents
=
[
body
];
this
.
_webview
.
onDidClickLink
(
link
=>
this
.
openerService
.
open
(
link
),
null
,
this
.
contentDisposables
);
this
.
_webview
.
onDidScroll
(
event
=>
{
this
.
scrollYPercentage
=
event
.
scrollYPercentage
;
},
null
,
this
.
contentDisposables
);
this
.
themeService
.
onThemeChange
(
this
.
onThemeChange
,
this
,
this
.
contentDisposables
);
this
.
contentDisposables
.
push
(
this
.
_webview
);
this
.
contentDisposables
.
push
(
toDisposable
(()
=>
this
.
_webview
=
null
));
}
layout
():
void
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录