Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
09b83d34
V
vscode
项目概览
掘金者说
/
vscode
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
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,发现更多精彩内容 >>
提交
09b83d34
编写于
1月 24, 2020
作者:
J
Johannes Rieken
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
bulk - better view model
上级
e57ba0c8
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
34 addition
and
31 deletion
+34
-31
src/vs/workbench/contrib/bulkEdit/browser/bulkEditPane.ts
src/vs/workbench/contrib/bulkEdit/browser/bulkEditPane.ts
+8
-8
src/vs/workbench/contrib/bulkEdit/browser/bulkEditTree.ts
src/vs/workbench/contrib/bulkEdit/browser/bulkEditTree.ts
+26
-23
未找到文件。
src/vs/workbench/contrib/bulkEdit/browser/bulkEditPane.ts
浏览文件 @
09b83d34
...
...
@@ -6,7 +6,7 @@
import
'
vs/css!./media/bulkEdit
'
;
import
{
WorkbenchAsyncDataTree
,
TreeResourceNavigator
,
IOpenEvent
}
from
'
vs/platform/list/browser/listService
'
;
import
{
WorkspaceEdit
}
from
'
vs/editor/common/modes
'
;
import
{
BulkEditElement
,
BulkEditDelegate
,
TextEditElementRenderer
,
FileElementRenderer
,
BulkEditDataSource
,
BulkEditIdentityProvider
,
FileElement
,
TextEditElement
,
BulkEditAccessibilityProvider
,
BulkEditAriaProvider
,
CategoryElementRenderer
,
BulkEditNaviLabelProvider
}
from
'
vs/workbench/contrib/bulkEdit/browser/bulkEditTree
'
;
import
{
BulkEditElement
,
BulkEditDelegate
,
TextEditElementRenderer
,
FileElementRenderer
,
BulkEditDataSource
,
BulkEditIdentityProvider
,
FileElement
,
TextEditElement
,
BulkEditAccessibilityProvider
,
BulkEditAriaProvider
,
CategoryElementRenderer
,
BulkEditNaviLabelProvider
,
CategoryElement
}
from
'
vs/workbench/contrib/bulkEdit/browser/bulkEditTree
'
;
import
{
FuzzyScore
}
from
'
vs/base/common/filters
'
;
import
{
IInstantiationService
}
from
'
vs/platform/instantiation/common/instantiation
'
;
import
{
registerThemingParticipant
,
ITheme
,
ICssStyleCollector
}
from
'
vs/platform/theme/common/themeService
'
;
...
...
@@ -14,7 +14,7 @@ import { diffInserted, diffRemoved } from 'vs/platform/theme/common/colorRegistr
import
{
localize
}
from
'
vs/nls
'
;
import
{
DisposableStore
}
from
'
vs/base/common/lifecycle
'
;
import
{
IEditorService
}
from
'
vs/workbench/services/editor/common/editorService
'
;
import
{
BulkEditPreviewProvider
,
BulkFileOperations
,
BulkFileOperationType
,
BulkCategory
}
from
'
vs/workbench/contrib/bulkEdit/browser/bulkEditPreview
'
;
import
{
BulkEditPreviewProvider
,
BulkFileOperations
,
BulkFileOperationType
}
from
'
vs/workbench/contrib/bulkEdit/browser/bulkEditPreview
'
;
import
{
ILabelService
}
from
'
vs/platform/label/common/label
'
;
import
{
ITextModelService
}
from
'
vs/editor/common/services/resolverService
'
;
import
{
URI
}
from
'
vs/base/common/uri
'
;
...
...
@@ -206,7 +206,7 @@ export class BulkEditPane extends ViewPane {
if
(
element
instanceof
FileElement
)
{
await
this
.
_tree
.
expand
(
element
,
true
);
}
if
(
element
instanceof
BulkCategory
)
{
if
(
element
instanceof
CategoryElement
)
{
await
this
.
_tree
.
expand
(
element
,
true
);
expand
.
push
(...
this
.
_tree
.
getNode
(
element
).
children
);
}
...
...
@@ -307,21 +307,21 @@ export class BulkEditPane extends ViewPane {
let
leftResource
:
URI
|
undefined
;
if
(
fileElement
.
edit
.
type
&
BulkFileOperationType
.
TextEdit
)
{
try
{
(
await
this
.
_textModelService
.
createModelReference
(
fileElement
.
uri
)).
dispose
();
leftResource
=
fileElement
.
uri
;
(
await
this
.
_textModelService
.
createModelReference
(
fileElement
.
edit
.
uri
)).
dispose
();
leftResource
=
fileElement
.
edit
.
uri
;
}
catch
{
leftResource
=
BulkEditPreviewProvider
.
emptyPreview
;
}
}
const
previewUri
=
BulkEditPreviewProvider
.
asPreviewUri
(
fileElement
.
uri
);
const
previewUri
=
BulkEditPreviewProvider
.
asPreviewUri
(
fileElement
.
edit
.
uri
);
if
(
leftResource
)
{
// show diff editor
this
.
_editorService
.
openEditor
({
leftResource
,
rightResource
:
previewUri
,
label
:
localize
(
'
edt.title
'
,
"
{0} (refactor preview)
"
,
basename
(
fileElement
.
uri
)),
label
:
localize
(
'
edt.title
'
,
"
{0} (refactor preview)
"
,
basename
(
fileElement
.
edit
.
uri
)),
options
});
}
else
{
...
...
@@ -336,7 +336,7 @@ export class BulkEditPane extends ViewPane {
}
this
.
_editorService
.
openEditor
({
label
:
typeLabel
&&
localize
(
'
edt.title2
'
,
"
{0} ({1}, refactor preview)
"
,
basename
(
fileElement
.
uri
),
typeLabel
),
label
:
typeLabel
&&
localize
(
'
edt.title2
'
,
"
{0} ({1}, refactor preview)
"
,
basename
(
fileElement
.
edit
.
uri
),
typeLabel
),
resource
:
previewUri
,
options
});
...
...
src/vs/workbench/contrib/bulkEdit/browser/bulkEditTree.ts
浏览文件 @
09b83d34
...
...
@@ -7,7 +7,6 @@ import { IAsyncDataSource, ITreeRenderer, ITreeNode } from 'vs/base/browser/ui/t
import
{
ITextModelService
}
from
'
vs/editor/common/services/resolverService
'
;
import
{
FuzzyScore
,
createMatches
}
from
'
vs/base/common/filters
'
;
import
{
IResourceLabel
,
ResourceLabels
}
from
'
vs/workbench/browser/labels
'
;
import
{
URI
}
from
'
vs/base/common/uri
'
;
import
{
HighlightedLabel
,
IHighlight
}
from
'
vs/base/browser/ui/highlightedlabel/highlightedLabel
'
;
import
{
IIdentityProvider
,
IListVirtualDelegate
,
IKeyboardNavigationLabelProvider
}
from
'
vs/base/browser/ui/list/list
'
;
import
{
Range
}
from
'
vs/editor/common/core/range
'
;
...
...
@@ -27,16 +26,20 @@ import { ThemeIcon } from 'vs/platform/theme/common/themeService';
// --- VIEW MODEL
export
class
File
Element
{
export
class
Category
Element
{
readonly
uri
:
URI
;
constructor
(
readonly
parent
:
BulkFileOperations
,
readonly
category
:
BulkCategory
)
{
}
}
export
class
FileElement
{
constructor
(
readonly
parent
:
BulkCategory
|
undefined
,
readonly
parent
:
CategoryElement
|
BulkFileOperations
,
readonly
edit
:
BulkFileOperation
)
{
this
.
uri
=
edit
.
uri
;
}
)
{
}
}
export
class
TextEditElement
{
...
...
@@ -48,7 +51,7 @@ export class TextEditElement {
)
{
}
}
export
type
BulkEditElement
=
BulkCategory
|
FileElement
|
TextEditElement
;
export
type
BulkEditElement
=
CategoryElement
|
FileElement
|
TextEditElement
;
// --- DATA SOURCE
...
...
@@ -73,13 +76,13 @@ export class BulkEditDataSource implements IAsyncDataSource<BulkFileOperations,
// root -> file/text edits
if
(
element
instanceof
BulkFileOperations
)
{
return
this
.
groupByFile
?
element
.
fileOperations
.
map
(
op
=>
new
FileElement
(
undefined
,
op
))
:
element
.
categories
;
?
element
.
fileOperations
.
map
(
op
=>
new
FileElement
(
element
,
op
))
:
element
.
categories
.
map
(
cat
=>
new
CategoryElement
(
element
,
cat
))
;
}
// category
if
(
element
instanceof
BulkCategory
)
{
return
element
.
fileOperations
.
map
(
op
=>
new
FileElement
(
element
,
op
));
if
(
element
instanceof
CategoryElement
)
{
return
element
.
category
.
fileOperations
.
map
(
op
=>
new
FileElement
(
element
,
op
));
}
// file: text edit
...
...
@@ -209,11 +212,11 @@ export class BulkEditIdentityProvider implements IIdentityProvider<BulkEditEleme
getId
(
element
:
BulkEditElement
):
{
toString
():
string
;
}
{
if
(
element
instanceof
FileElement
)
{
return
element
.
uri
+
JSON
.
stringify
(
element
.
parent
?.
metadata
);
return
element
.
edit
.
uri
+
(
element
.
parent
instanceof
CategoryElement
?
JSON
.
stringify
(
element
.
parent
.
category
.
metadata
)
:
''
);
}
else
if
(
element
instanceof
TextEditElement
)
{
return
element
.
parent
.
uri
.
toString
()
+
JSON
.
stringify
(
element
.
edit
.
textEdit
);
return
element
.
parent
.
edit
.
uri
.
toString
()
+
JSON
.
stringify
(
element
.
edit
.
textEdit
);
}
else
{
return
JSON
.
stringify
(
element
.
metadata
);
return
JSON
.
stringify
(
element
.
category
.
metadata
);
}
}
}
...
...
@@ -248,7 +251,7 @@ class CategoryElementTemplate {
}
}
export
class
CategoryElementRenderer
implements
ITreeRenderer
<
BulkCategory
,
FuzzyScore
,
CategoryElementTemplate
>
{
export
class
CategoryElementRenderer
implements
ITreeRenderer
<
CategoryElement
,
FuzzyScore
,
CategoryElementTemplate
>
{
static
readonly
id
:
string
=
'
CategoryElementRenderer
'
;
...
...
@@ -258,12 +261,12 @@ export class CategoryElementRenderer implements ITreeRenderer<BulkCategory, Fuzz
return
new
CategoryElementTemplate
(
container
);
}
renderElement
(
node
:
ITreeNode
<
BulkCategory
,
FuzzyScore
>
,
_index
:
number
,
template
:
CategoryElementTemplate
):
void
{
renderElement
(
node
:
ITreeNode
<
CategoryElement
,
FuzzyScore
>
,
_index
:
number
,
template
:
CategoryElementTemplate
):
void
{
template
.
icon
.
style
.
setProperty
(
'
--background-dark
'
,
null
);
template
.
icon
.
style
.
setProperty
(
'
--background-light
'
,
null
);
const
{
metadata
}
=
node
.
element
;
const
{
metadata
}
=
node
.
element
.
category
;
if
(
ThemeIcon
.
isThemeIcon
(
metadata
.
iconPath
))
{
// css
const
className
=
ThemeIcon
.
asClassName
(
metadata
.
iconPath
);
...
...
@@ -340,12 +343,12 @@ class FileElementTemplate {
this
.
_details
.
innerText
=
localize
(
'
detail.rename
'
,
"
(renaming from {0})
"
,
this
.
_labelService
.
getUriLabel
(
element
.
uri
,
{
relative
:
true
})
this
.
_labelService
.
getUriLabel
(
element
.
edit
.
uri
,
{
relative
:
true
})
);
}
else
{
// create, delete, edit: NAME
this
.
_label
.
setFile
(
element
.
uri
,
{
this
.
_label
.
setFile
(
element
.
edit
.
uri
,
{
matches
:
createMatches
(
score
),
fileKind
:
FileKind
.
FILE
,
fileDecorations
:
{
colors
:
true
,
badges
:
false
},
...
...
@@ -489,9 +492,9 @@ export class BulkEditNaviLabelProvider implements IKeyboardNavigationLabelProvid
getKeyboardNavigationLabel
(
element
:
BulkEditElement
)
{
if
(
element
instanceof
FileElement
)
{
return
basename
(
element
.
uri
);
}
else
if
(
element
instanceof
BulkCategory
)
{
return
element
.
metadata
.
label
;
return
basename
(
element
.
edit
.
uri
);
}
else
if
(
element
instanceof
CategoryElement
)
{
return
element
.
category
.
metadata
.
label
;
}
return
undefined
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录