Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
a3d61cb0
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,发现更多精彩内容 >>
未验证
提交
a3d61cb0
编写于
4月 16, 2021
作者:
D
Daniel Imms
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add change icon/configure terminal action
Fixes #121467
上级
0b9c11a4
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
70 addition
and
3 deletion
+70
-3
src/vs/workbench/contrib/terminal/browser/terminal.ts
src/vs/workbench/contrib/terminal/browser/terminal.ts
+10
-0
src/vs/workbench/contrib/terminal/browser/terminalActions.ts
src/vs/workbench/contrib/terminal/browser/terminalActions.ts
+28
-0
src/vs/workbench/contrib/terminal/browser/terminalInstance.ts
...vs/workbench/contrib/terminal/browser/terminalInstance.ts
+28
-1
src/vs/workbench/contrib/terminal/browser/terminalTabsWidget.ts
.../workbench/contrib/terminal/browser/terminalTabsWidget.ts
+2
-2
src/vs/workbench/contrib/terminal/common/terminal.ts
src/vs/workbench/contrib/terminal/common/terminal.ts
+2
-0
未找到文件。
src/vs/workbench/contrib/terminal/browser/terminal.ts
浏览文件 @
a3d61cb0
...
...
@@ -576,4 +576,14 @@ export interface ITerminalInstance {
* Triggers a quick pick to rename this terminal.
*/
rename
():
Promise
<
void
>
;
/**
* Triggers a quick pick to rename this terminal.
*/
changeIcon
():
Promise
<
void
>
;
/**
* Allows the user to configure this terminal.
*/
configure
():
Promise
<
void
>
;
}
src/vs/workbench/contrib/terminal/browser/terminalActions.ts
浏览文件 @
a3d61cb0
...
...
@@ -616,6 +616,34 @@ export function registerTerminalActions() {
}
}
});
registerAction2
(
class
extends
Action2
{
constructor
()
{
super
({
id
:
TERMINAL_COMMAND_ID
.
CONFIGURE_ACTIVE
,
title
:
{
value
:
localize
(
'
workbench.action.terminal.configureActive
'
,
"
Configure Active Terminal
"
),
original
:
'
Configure Active Terminal
'
},
f1
:
true
,
category
,
precondition
:
KEYBINDING_CONTEXT_TERMINAL_PROCESS_SUPPORTED
});
}
async
run
(
accessor
:
ServicesAccessor
)
{
return
accessor
.
get
(
ITerminalService
).
getActiveInstance
()?.
configure
();
}
});
registerAction2
(
class
extends
Action2
{
constructor
()
{
super
({
id
:
TERMINAL_COMMAND_ID
.
CHANGE_ICON
,
title
:
{
value
:
localize
(
'
workbench.action.terminal.changeIcon
'
,
"
Change Icon
"
),
original
:
'
Change Icon
'
},
f1
:
true
,
category
,
precondition
:
KEYBINDING_CONTEXT_TERMINAL_PROCESS_SUPPORTED
});
}
async
run
(
accessor
:
ServicesAccessor
)
{
return
accessor
.
get
(
ITerminalService
).
getActiveInstance
()?.
changeIcon
();
}
});
registerAction2
(
class
extends
Action2
{
constructor
()
{
super
({
...
...
src/vs/workbench/contrib/terminal/browser/terminalInstance.ts
浏览文件 @
a3d61cb0
...
...
@@ -52,7 +52,7 @@ import { formatMessageForTerminal } from 'vs/workbench/contrib/terminal/common/t
import
{
AutoOpenBarrier
}
from
'
vs/base/common/async
'
;
import
{
Codicon
,
iconRegistry
}
from
'
vs/base/common/codicons
'
;
import
{
ITerminalStatusList
,
TerminalStatus
,
TerminalStatusList
}
from
'
vs/workbench/contrib/terminal/browser/terminalStatusList
'
;
import
{
IQuickInputService
}
from
'
vs/platform/quickinput/common/quickInput
'
;
import
{
IQuickInputService
,
IQuickPickItem
}
from
'
vs/platform/quickinput/common/quickInput
'
;
import
{
IWorkbenchEnvironmentService
}
from
'
vs/workbench/services/environment/common/environmentService
'
;
import
{
isMacintosh
,
isWindows
,
OperatingSystem
,
OS
}
from
'
vs/base/common/platform
'
;
...
...
@@ -1744,6 +1744,33 @@ export class TerminalInstance extends Disposable implements ITerminalInstance {
this
.
setTitle
(
name
,
TitleEventSource
.
Api
);
}
}
public
async
changeIcon
()
{
const
items
:
IQuickPickItem
[]
=
[];
for
(
const
icon
of
iconRegistry
.
all
)
{
items
.
push
({
label
:
`$(
${
icon
.
id
}
)`
,
description
:
`
${
icon
.
id
}
`
});
}
const
result
=
await
this
.
_quickInputService
.
pick
(
items
,
{
title
:
nls
.
localize
(
'
changeTerminalIcon
'
,
"
Change Icon
"
),
matchOnDescription
:
true
});
if
(
result
)
{
this
.
shellLaunchConfig
.
icon
=
result
.
description
;
this
.
_onTitleChanged
.
fire
(
this
);
}
}
public
async
configure
():
Promise
<
void
>
{
const
changeIcon
:
IQuickPickItem
=
{
label
:
nls
.
localize
(
'
changeIconTerminal
'
,
'
Change Icon
'
)
};
const
rename
:
IQuickPickItem
=
{
label
:
nls
.
localize
(
'
renameTerminal
'
,
'
Rename
'
)
};
const
result
=
await
this
.
_quickInputService
.
pick
([
changeIcon
,
rename
],
{
title
:
nls
.
localize
(
'
configureTerminalTitle
'
,
"
Configure Terminal
"
)
});
switch
(
result
)
{
case
changeIcon
:
return
this
.
changeIcon
();
case
rename
:
return
this
.
rename
();
}
}
}
registerThemingParticipant
((
theme
:
IColorTheme
,
collector
:
ICssStyleCollector
)
=>
{
...
...
src/vs/workbench/contrib/terminal/browser/terminalTabsWidget.ts
浏览文件 @
a3d61cb0
...
...
@@ -222,12 +222,12 @@ class TerminalTabsRenderer implements ITreeRenderer<ITerminalInstance, never, IT
}
fillActionBar
(
instance
:
ITerminalInstance
,
template
:
ITerminalTabEntryTemplate
):
void
{
const
rename
=
new
Action
(
TERMINAL_COMMAND_ID
.
RENAME
,
localize
(
'
terminal.rename
'
,
"
Rename
"
),
ThemeIcon
.
asClassName
(
Codicon
.
tag
),
true
,
()
=>
instance
.
renam
e
());
const
configure
=
new
Action
(
TERMINAL_COMMAND_ID
.
CONFIGURE_ACTIVE
,
localize
(
'
terminal.configure
'
,
"
Configure
"
),
ThemeIcon
.
asClassName
(
Codicon
.
gear
),
true
,
()
=>
instance
.
configur
e
());
const
split
=
new
Action
(
TERMINAL_COMMAND_ID
.
SPLIT
,
localize
(
'
terminal.split
'
,
"
Split
"
),
ThemeIcon
.
asClassName
(
Codicon
.
splitHorizontal
),
true
,
async
()
=>
this
.
_terminalService
.
splitInstance
(
instance
));
const
kill
=
new
Action
(
TERMINAL_COMMAND_ID
.
KILL
,
localize
(
'
terminal.kill
'
,
"
Kill
"
),
ThemeIcon
.
asClassName
(
Codicon
.
trashcan
),
true
,
async
()
=>
instance
.
dispose
(
true
));
// TODO: Cache these in a way that will use the correct instance
template
.
actionBar
.
clear
();
template
.
actionBar
.
push
(
renam
e
,
{
icon
:
true
,
label
:
false
});
template
.
actionBar
.
push
(
configur
e
,
{
icon
:
true
,
label
:
false
});
template
.
actionBar
.
push
(
split
,
{
icon
:
true
,
label
:
false
});
template
.
actionBar
.
push
(
kill
,
{
icon
:
true
,
label
:
false
});
}
...
...
src/vs/workbench/contrib/terminal/common/terminal.ts
浏览文件 @
a3d61cb0
...
...
@@ -453,6 +453,8 @@ export const enum TERMINAL_COMMAND_ID {
SCROLL_TO_TOP
=
'
workbench.action.terminal.scrollToTop
'
,
CLEAR
=
'
workbench.action.terminal.clear
'
,
CLEAR_SELECTION
=
'
workbench.action.terminal.clearSelection
'
,
CONFIGURE_ACTIVE
=
'
workbench.action.terminal.configureActive
'
,
CHANGE_ICON
=
'
workbench.action.terminal.changeIcon
'
,
RENAME
=
'
workbench.action.terminal.rename
'
,
RENAME_WITH_ARG
=
'
workbench.action.terminal.renameWithArg
'
,
FIND_FOCUS
=
'
workbench.action.terminal.focusFind
'
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录