Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
后端镜像
Tabby
提交
ceacf5c7
T
Tabby
项目概览
后端镜像
/
Tabby
通知
41
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
Tabby
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
ceacf5c7
编写于
10月 22, 2017
作者:
E
Eugene Pankov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
added tab context menu (ref #219)
上级
e0c0cd17
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
59 addition
and
6 deletion
+59
-6
terminus-core/src/components/appRoot.component.pug
terminus-core/src/components/appRoot.component.pug
+0
-1
terminus-core/src/components/tabHeader.component.pug
terminus-core/src/components/tabHeader.component.pug
+1
-1
terminus-core/src/components/tabHeader.component.ts
terminus-core/src/components/tabHeader.component.ts
+58
-4
未找到文件。
terminus-core/src/components/appRoot.component.pug
浏览文件 @
ceacf5c7
...
...
@@ -19,7 +19,6 @@ title-bar(
[class.drag-region]='hostApp.platform == Platform.macOS',
@animateTab,
(click)='app.selectTab(tab)',
(closeClicked)='app.closeTab(tab, true)',
)
.btn-group
...
...
terminus-core/src/components/tabHeader.component.pug
浏览文件 @
ceacf5c7
.index {{index + 1}}
.name([title]='tab.customTitle || tab.title') {{tab.customTitle || tab.title}}
button((click)='
closeClicked.emit(
)') ×
button((click)='
app.closeTab(tab, true
)') ×
terminus-core/src/components/tabHeader.component.ts
浏览文件 @
ceacf5c7
import
{
Component
,
Input
,
Output
,
EventEmitter
,
HostBinding
,
HostListener
}
from
'
@angular/core
'
import
{
Component
,
Input
,
HostBinding
,
HostListener
,
NgZone
}
from
'
@angular/core
'
import
{
NgbModal
}
from
'
@ng-bootstrap/ng-bootstrap
'
import
{
BaseTabComponent
}
from
'
./baseTab.component
'
import
{
RenameTabModalComponent
}
from
'
./renameTabModal.component
'
import
{
ElectronService
}
from
'
../services/electron.service
'
import
{
AppService
}
from
'
../services/app.service
'
@
Component
({
selector
:
'
tab-header
'
,
...
...
@@ -13,11 +15,55 @@ export class TabHeaderComponent {
@
Input
()
@
HostBinding
(
'
class.active
'
)
active
:
boolean
@
Input
()
@
HostBinding
(
'
class.has-activity
'
)
hasActivity
:
boolean
@
Input
()
tab
:
BaseTabComponent
@
Output
()
closeClicked
=
new
EventEmitter
()
private
contextMenu
:
any
constructor
(
zone
:
NgZone
,
electron
:
ElectronService
,
public
app
:
AppService
,
private
ngbModal
:
NgbModal
,
)
{
}
)
{
this
.
contextMenu
=
electron
.
remote
.
Menu
.
buildFromTemplate
([
{
label
:
'
Close
'
,
click
:
()
=>
{
this
.
zone
.
run
(()
=>
{
app
.
closeTab
(
this
.
tab
,
true
)
})
}
},
{
label
:
'
Close other tabs
'
,
click
:
()
=>
{
zone
.
run
(()
=>
{
for
(
let
tab
of
app
.
tabs
.
filter
(
x
=>
x
!==
this
.
tab
))
{
app
.
closeTab
(
tab
,
true
)
}
})
}
},
{
label
:
'
Close tabs to the right
'
,
click
:
()
=>
{
zone
.
run
(()
=>
{
for
(
let
tab
of
app
.
tabs
.
slice
(
app
.
tabs
.
indexOf
(
this
.
tab
)
+
1
))
{
app
.
closeTab
(
tab
,
true
)
}
})
}
},
{
label
:
'
Close tabs to the left
'
,
click
:
()
=>
{
zone
.
run
(()
=>
{
for
(
let
tab
of
app
.
tabs
.
slice
(
0
,
app
.
tabs
.
indexOf
(
this
.
tab
)))
{
app
.
closeTab
(
tab
,
true
)
}
})
}
},
])
}
@
HostListener
(
'
dblclick
'
)
onDoubleClick
():
void
{
let
modal
=
this
.
ngbModal
.
open
(
RenameTabModalComponent
)
...
...
@@ -29,7 +75,15 @@ export class TabHeaderComponent {
@
HostListener
(
'
auxclick
'
,
[
'
$event
'
])
onAuxClick
(
$event
:
MouseEvent
):
void
{
if
(
$event
.
which
===
2
)
{
this
.
closeClicked
.
emit
()
this
.
app
.
closeTab
(
this
.
tab
,
true
)
}
if
(
$event
.
which
===
3
)
{
this
.
contextMenu
.
popup
({
x
:
$event
.
pageX
,
y
:
$event
.
pageY
,
async
:
true
,
})
event
.
preventDefault
()
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录