Added additional signals
This commit is contained in:
parent
0d48fb83d1
commit
f391bf8bd2
@ -1,3 +1,6 @@
|
|||||||
|
# Python imports
|
||||||
|
import threading
|
||||||
|
|
||||||
# Gtk imports
|
# Gtk imports
|
||||||
import gi
|
import gi
|
||||||
gi.require_version('Gtk', '3.0')
|
gi.require_version('Gtk', '3.0')
|
||||||
@ -10,9 +13,6 @@ from gi.repository import Gdk as gdk
|
|||||||
from gi.repository import GLib
|
from gi.repository import GLib
|
||||||
|
|
||||||
|
|
||||||
# Python imports
|
|
||||||
import threading
|
|
||||||
|
|
||||||
# Application imports
|
# Application imports
|
||||||
|
|
||||||
|
|
||||||
@ -54,17 +54,22 @@ class TaskbarSignals:
|
|||||||
if workspace and w.get_workspace():
|
if workspace and w.get_workspace():
|
||||||
wnum = w.get_workspace().get_number()
|
wnum = w.get_workspace().get_number()
|
||||||
if not w.is_skip_pager() and not w.is_skip_tasklist() and wnum == self.actv_workspace_num:
|
if not w.is_skip_pager() and not w.is_skip_tasklist() and wnum == self.actv_workspace_num:
|
||||||
|
self.createWinLink(w)
|
||||||
|
|
||||||
|
def setScreenSignals(self):
|
||||||
|
self.SCREEN.connect("active-workspace-changed", self.activeWorkspaceChanged)
|
||||||
|
self.SCREEN.connect("window-opened", self.windowOpened)
|
||||||
|
self.SCREEN.connect("window-closed", self.windowClosed)
|
||||||
|
|
||||||
|
def createWinLink(self, w):
|
||||||
btn = self.createWinBttn(w)
|
btn = self.createWinBttn(w)
|
||||||
self.setupSignals(btn, w)
|
self.setupSignals(btn, w)
|
||||||
self.taskBarButtons.add(btn)
|
self.taskBarButtons.add(btn)
|
||||||
|
|
||||||
def setupSignals(self, btn, win):
|
def setupSignals(self, btn, win):
|
||||||
btn.connect("button-press-event", self.clickEvent, (win))
|
btn.connect("button-press-event", self.clickEvent, (win))
|
||||||
|
win.connect("name_changed", self.windowNameChanged, (btn))
|
||||||
def setScreenSignals(self):
|
win.connect("workspace_changed", self.windowWorkspaceChanged, (btn))
|
||||||
self.SCREEN.connect("active-workspace-changed", self.activeWorkspaceChanged)
|
|
||||||
self.SCREEN.connect("window-opened", self.windowOpened)
|
|
||||||
self.SCREEN.connect("window-closed", self.windowClosed)
|
|
||||||
|
|
||||||
def createWinBttn(self, w):
|
def createWinBttn(self, w):
|
||||||
btn = gtk.Button(label=w.get_name(), always_show_image=True)
|
btn = gtk.Button(label=w.get_name(), always_show_image=True)
|
||||||
@ -123,7 +128,7 @@ class TaskbarSignals:
|
|||||||
|
|
||||||
|
|
||||||
def hideTaskbarMenu(self, widget, eve):
|
def hideTaskbarMenu(self, widget, eve):
|
||||||
widget.hide()
|
self.taskbarMenu.hide()
|
||||||
|
|
||||||
def setPagerWidget(self):
|
def setPagerWidget(self):
|
||||||
pager = wnck.Pager()
|
pager = wnck.Pager()
|
||||||
@ -139,16 +144,26 @@ class TaskbarSignals:
|
|||||||
self.SCREEN.force_update() # (Re)populate screen windows list
|
self.SCREEN.force_update() # (Re)populate screen windows list
|
||||||
self.refreashTaskbar()
|
self.refreashTaskbar()
|
||||||
|
|
||||||
|
def windowClosed(self, screen, window):
|
||||||
|
self.clearChildren(self.taskBarButtons)
|
||||||
|
self.SCREEN.force_update() # (Re)populate screen windows list
|
||||||
|
self.refreashTaskbar()
|
||||||
|
|
||||||
def windowOpened(self, screen, window):
|
def windowOpened(self, screen, window):
|
||||||
self.SCREEN.force_update() # (Re)populate screen windows list
|
self.SCREEN.force_update() # (Re)populate screen windows list
|
||||||
btn = self.createWinBttn(window)
|
btn = self.createWinBttn(window)
|
||||||
self.setupSignals(btn, window)
|
self.setupSignals(btn, window)
|
||||||
self.taskBarButtons.add(btn)
|
self.taskBarButtons.add(btn)
|
||||||
|
|
||||||
def windowClosed(self, screen, window):
|
def windowNameChanged(self, win, btn):
|
||||||
self.clearChildren(self.taskBarButtons)
|
btn.set_label(win.get_name())
|
||||||
self.SCREEN.force_update() # (Re)populate screen windows list
|
|
||||||
self.refreashTaskbar()
|
def windowWorkspaceChanged(self, win, btn):
|
||||||
|
wnum = win.get_workspace().get_number()
|
||||||
|
if self.actv_workspace_num == wnum:
|
||||||
|
btn.show()
|
||||||
|
else:
|
||||||
|
btn.hide()
|
||||||
|
|
||||||
def clearChildren(self, parent):
|
def clearChildren(self, parent):
|
||||||
children = parent.get_children();
|
children = parent.get_children();
|
||||||
@ -198,6 +213,7 @@ class TaskbarSignals:
|
|||||||
|
|
||||||
def closeAppWindow(self, widget, data=None):
|
def closeAppWindow(self, widget, data=None):
|
||||||
self.window.close(1)
|
self.window.close(1)
|
||||||
|
self.hideTaskbarMenu(None, None)
|
||||||
|
|
||||||
|
|
||||||
# WINDOW_SIGNALS
|
# WINDOW_SIGNALS
|
||||||
|
Loading…
Reference in New Issue
Block a user