aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/ui/tab.go16
-rw-r--r--widgets/aerc.go4
2 files changed, 20 insertions, 0 deletions
diff --git a/lib/ui/tab.go b/lib/ui/tab.go
index ed96ec4..61d544a 100644
--- a/lib/ui/tab.go
+++ b/lib/ui/tab.go
@@ -68,6 +68,22 @@ func (tabs *Tabs) Remove(content Drawable) {
tabs.TabStrip.Invalidate()
}
+func (tabs *Tabs) Replace(contentSrc Drawable, contentTarget Drawable, name string) {
+ replaceTab := &Tab{
+ Content: contentTarget,
+ Name: name,
+ }
+ for i, tab := range tabs.Tabs {
+ if tab.Content == contentSrc {
+ tabs.Tabs[i] = replaceTab
+ tabs.Select(i)
+ break
+ }
+ }
+ tabs.TabStrip.Invalidate()
+ contentTarget.OnInvalidate(tabs.invalidateChild)
+}
+
func (tabs *Tabs) Select(index int) {
if index >= len(tabs.Tabs) {
panic("Tried to set tab index to a non-existing element")
diff --git a/widgets/aerc.go b/widgets/aerc.go
index 5b1b151..ae8319b 100644
--- a/widgets/aerc.go
+++ b/widgets/aerc.go
@@ -218,6 +218,10 @@ func (aerc *Aerc) RemoveTab(tab ui.Drawable) {
aerc.tabs.Remove(tab)
}
+func (aerc *Aerc) ReplaceTab(tabSrc ui.Drawable, tabTarget ui.Drawable, name string) {
+ aerc.tabs.Replace(tabSrc, tabTarget, name)
+}
+
func (aerc *Aerc) NextTab() {
next := aerc.tabs.Selected + 1
if next >= len(aerc.tabs.Tabs) {