Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
5fa4aad3
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,发现更多精彩内容 >>
提交
5fa4aad3
编写于
4月 23, 2019
作者:
M
Matt Bierner
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add ResourceViewerDelegate interface
上级
3a12b7ac
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
29 addition
and
26 deletion
+29
-26
src/vs/workbench/browser/parts/editor/binaryEditor.ts
src/vs/workbench/browser/parts/editor/binaryEditor.ts
+5
-3
src/vs/workbench/browser/parts/editor/resourceViewer.ts
src/vs/workbench/browser/parts/editor/resourceViewer.ts
+24
-23
未找到文件。
src/vs/workbench/browser/parts/editor/binaryEditor.ts
浏览文件 @
5fa4aad3
...
...
@@ -92,9 +92,11 @@ export abstract class BaseBinaryResourceEditor extends BaseEditor {
this
.
textFileService
,
this
.
binaryContainer
,
this
.
scrollbar
,
resource
=>
this
.
handleOpenInternalCallback
(
input
,
options
),
resource
=>
this
.
callbacks
.
openExternal
(
resource
),
meta
=>
this
.
handleMetadataChanged
(
meta
)
{
openInternalClb
:
resource
=>
this
.
handleOpenInternalCallback
(
input
,
options
),
openExternalClb
:
resource
=>
this
.
callbacks
.
openExternal
(
resource
),
metadataClb
:
meta
=>
this
.
handleMetadataChanged
(
meta
)
}
);
return
undefined
;
...
...
src/vs/workbench/browser/parts/editor/resourceViewer.ts
浏览文件 @
5fa4aad3
...
...
@@ -62,6 +62,12 @@ export interface ResourceViewerContext extends IDisposable {
layout
?(
dimension
:
DOM
.
Dimension
):
void
;
}
interface
ResourceViewerDelegate
{
openInternalClb
(
uri
:
URI
):
void
;
openExternalClb
(
uri
:
URI
):
void
;
metadataClb
(
meta
:
string
):
void
;
}
/**
* Helper to actually render the given resource into the provided container. Will adjust scrollbar (if provided) automatically based on loading
* progress of the binary resource.
...
...
@@ -75,9 +81,7 @@ export class ResourceViewer {
textFileService
:
ITextFileService
,
container
:
HTMLElement
,
scrollbar
:
DomScrollableElement
,
openInternalClb
:
(
uri
:
URI
)
=>
void
,
openExternalClb
:
(
uri
:
URI
)
=>
void
,
metadataClb
:
(
meta
:
string
)
=>
void
delegate
:
ResourceViewerDelegate
):
ResourceViewerContext
{
// Ensure CSS class
...
...
@@ -85,17 +89,17 @@ export class ResourceViewer {
// Images
if
(
ResourceViewer
.
isImageResource
(
descriptor
))
{
return
ImageView
.
create
(
container
,
descriptor
,
textFileService
,
scrollbar
,
openExternalClb
,
metadataClb
);
return
ImageView
.
create
(
container
,
descriptor
,
textFileService
,
scrollbar
,
delegate
);
}
// Large Files
if
(
descriptor
.
size
>
ResourceViewer
.
MAX_OPEN_INTERNAL_SIZE
)
{
return
FileTooLargeFileView
.
create
(
container
,
descriptor
,
scrollbar
,
metadataClb
);
return
FileTooLargeFileView
.
create
(
container
,
descriptor
,
scrollbar
,
delegate
);
}
// Seemingly Binary Files
else
{
return
FileSeemsBinaryFileView
.
create
(
container
,
descriptor
,
scrollbar
,
openInternalClb
,
metadataClb
);
return
FileSeemsBinaryFileView
.
create
(
container
,
descriptor
,
scrollbar
,
delegate
);
}
}
...
...
@@ -116,14 +120,13 @@ class ImageView {
descriptor
:
IResourceDescriptor
,
textFileService
:
ITextFileService
,
scrollbar
:
DomScrollableElement
,
openExternalClb
:
(
uri
:
URI
)
=>
void
,
metadataClb
:
(
meta
:
string
)
=>
void
delegate
:
ResourceViewerDelegate
):
ResourceViewerContext
{
if
(
ImageView
.
shouldShowImageInline
(
descriptor
))
{
return
InlineImageView
.
create
(
container
,
descriptor
,
textFileService
,
scrollbar
,
metadataClb
);
return
InlineImageView
.
create
(
container
,
descriptor
,
textFileService
,
scrollbar
,
delegate
);
}
return
LargeImageView
.
create
(
container
,
descriptor
,
openExternalClb
,
metadataClb
);
return
LargeImageView
.
create
(
container
,
descriptor
,
delegate
);
}
private
static
shouldShowImageInline
(
descriptor
:
IResourceDescriptor
):
boolean
{
...
...
@@ -150,11 +153,10 @@ class LargeImageView {
static
create
(
container
:
HTMLElement
,
descriptor
:
IResourceDescriptor
,
openExternalClb
:
(
uri
:
URI
)
=>
void
,
metadataClb
:
(
meta
:
string
)
=>
void
delegate
:
ResourceViewerDelegate
)
{
const
size
=
BinarySize
.
formatSize
(
descriptor
.
size
);
metadataClb
(
size
);
delegate
.
metadataClb
(
size
);
DOM
.
clearNode
(
container
);
...
...
@@ -169,7 +171,7 @@ class LargeImageView {
link
.
setAttribute
(
'
role
'
,
'
button
'
);
link
.
textContent
=
nls
.
localize
(
'
resourceOpenExternalButton
'
,
"
Open image using external program?
"
);
disposables
.
push
(
DOM
.
addDisposableListener
(
link
,
DOM
.
EventType
.
CLICK
,
()
=>
openExternalClb
(
descriptor
.
resource
)));
disposables
.
push
(
DOM
.
addDisposableListener
(
link
,
DOM
.
EventType
.
CLICK
,
()
=>
delegate
.
openExternalClb
(
descriptor
.
resource
)));
}
return
combinedDisposable
(
disposables
);
...
...
@@ -181,10 +183,10 @@ class FileTooLargeFileView {
container
:
HTMLElement
,
descriptor
:
IResourceDescriptor
,
scrollbar
:
DomScrollableElement
,
metadataClb
:
(
meta
:
string
)
=>
void
delegate
:
ResourceViewerDelegate
)
{
const
size
=
BinarySize
.
formatSize
(
descriptor
.
size
);
metadataClb
(
size
);
delegate
.
metadataClb
(
size
);
DOM
.
clearNode
(
container
);
...
...
@@ -203,10 +205,9 @@ class FileSeemsBinaryFileView {
container
:
HTMLElement
,
descriptor
:
IResourceDescriptor
,
scrollbar
:
DomScrollableElement
,
openInternalClb
:
(
uri
:
URI
)
=>
void
,
metadataClb
:
(
meta
:
string
)
=>
void
delegate
:
ResourceViewerDelegate
)
{
metadataClb
(
typeof
descriptor
.
size
===
'
number
'
?
BinarySize
.
formatSize
(
descriptor
.
size
)
:
''
);
delegate
.
metadataClb
(
typeof
descriptor
.
size
===
'
number
'
?
BinarySize
.
formatSize
(
descriptor
.
size
)
:
''
);
DOM
.
clearNode
(
container
);
...
...
@@ -221,7 +222,7 @@ class FileSeemsBinaryFileView {
link
.
setAttribute
(
'
role
'
,
'
button
'
);
link
.
textContent
=
nls
.
localize
(
'
openAsText
'
,
"
Do you want to open it anyway?
"
);
disposables
.
push
(
DOM
.
addDisposableListener
(
link
,
DOM
.
EventType
.
CLICK
,
()
=>
openInternalClb
(
descriptor
.
resource
)));
disposables
.
push
(
DOM
.
addDisposableListener
(
link
,
DOM
.
EventType
.
CLICK
,
()
=>
delegate
.
openInternalClb
(
descriptor
.
resource
)));
}
scrollbar
.
scanDomNode
();
...
...
@@ -359,7 +360,7 @@ class InlineImageView {
descriptor
:
IResourceDescriptor
,
textFileService
:
ITextFileService
,
scrollbar
:
DomScrollableElement
,
metadataClb
:
(
meta
:
string
)
=>
void
delegate
:
ResourceViewerDelegate
)
{
const
disposables
:
IDisposable
[]
=
[];
...
...
@@ -543,9 +544,9 @@ class InlineImageView {
return
;
}
if
(
typeof
descriptor
.
size
===
'
number
'
)
{
metadataClb
(
nls
.
localize
(
'
imgMeta
'
,
'
{0}x{1} {2}
'
,
image
.
naturalWidth
,
image
.
naturalHeight
,
BinarySize
.
formatSize
(
descriptor
.
size
)));
delegate
.
metadataClb
(
nls
.
localize
(
'
imgMeta
'
,
'
{0}x{1} {2}
'
,
image
.
naturalWidth
,
image
.
naturalHeight
,
BinarySize
.
formatSize
(
descriptor
.
size
)));
}
else
{
metadataClb
(
nls
.
localize
(
'
imgMetaNoSize
'
,
'
{0}x{1}
'
,
image
.
naturalWidth
,
image
.
naturalHeight
));
delegate
.
metadataClb
(
nls
.
localize
(
'
imgMetaNoSize
'
,
'
{0}x{1}
'
,
image
.
naturalWidth
,
image
.
naturalHeight
));
}
scrollbar
.
scanDomNode
();
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录