Add 3. Adding a button to the toolbar
Signed-off-by: Juraj Oravec <sgd.orava@gmail.com>
This commit is contained in:
parent
cddf5d890a
commit
83f9cb4d35
224
articles/3. Adding a button to the toolbar.md
Normal file
224
articles/3. Adding a button to the toolbar.md
Normal file
@ -0,0 +1,224 @@
|
|||||||
|
# Falkon Python Tutorial - 3. Adding a button to the toolbar
|
||||||
|
|
||||||
|
In this chapter will be shown how to add Simple button to the toolbar.
|
||||||
|
The button has to be added to every window.
|
||||||
|
The button has to be added to new windows and removed when the window is closing.
|
||||||
|
|
||||||
|
## Fill metadata
|
||||||
|
It feels like a paperwork but it has to be done.
|
||||||
|
|
||||||
|
*metadata.desktop*
|
||||||
|
|
||||||
|
```
|
||||||
|
[Desktop Entry]
|
||||||
|
Name=Falkon Python Tutorial 3
|
||||||
|
Comment=Adding a button to the toolbar
|
||||||
|
Icon=
|
||||||
|
Type=Service
|
||||||
|
X-Falkon-Type=Extension/Python
|
||||||
|
|
||||||
|
X-Falkon-Author=Juraj Oravec
|
||||||
|
X-Falkon-Email=sgd.orava@gmail.com
|
||||||
|
X-Falkon-Version=1.0.0
|
||||||
|
X-Falkon-Settings=false
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
## Create button
|
||||||
|
|
||||||
|
*TutorialButton.py*
|
||||||
|
|
||||||
|
```python
|
||||||
|
import Falkon
|
||||||
|
|
||||||
|
|
||||||
|
class TutorialButton(Falkon.AbstractButtonInterface):
|
||||||
|
def __init__(self):
|
||||||
|
super().__init__()
|
||||||
|
|
||||||
|
self.number = 0
|
||||||
|
|
||||||
|
self.setTitle("Tutorial 3")
|
||||||
|
self.setToolTip("Increment the number")
|
||||||
|
self.setBadgeText(str())
|
||||||
|
|
||||||
|
self.clicked.connect(self.onClicked)
|
||||||
|
|
||||||
|
def id(self):
|
||||||
|
return "falkon-python-tutorial-3-button"
|
||||||
|
|
||||||
|
def name(self):
|
||||||
|
return "Falkon Python Tutorial 3 Button"
|
||||||
|
|
||||||
|
def onClicked(self, controller):
|
||||||
|
self.number += 1
|
||||||
|
self.setBadgeText(str(self.number))
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
The button class has to inherit from `Falkon.AbstractButtonInterface`[1]
|
||||||
|
|
||||||
|
### Falkon.AbstractButtonInterface
|
||||||
|
The interface class for Falkon buttons.
|
||||||
|
|
||||||
|
#### id()
|
||||||
|
This id will be used by Falkon when you add the button to toolbar to determinate its place in the toolbar.
|
||||||
|
|
||||||
|
#### name()
|
||||||
|
The name which will be displayed in "Configure toolbar" dialog.
|
||||||
|
|
||||||
|
#### setTitle()
|
||||||
|
I did not find a sensible use for this function in the Falkons code yet.
|
||||||
|
|
||||||
|
#### setToolTip()
|
||||||
|
The buttons tooltip which will be displayed when you hover with mouse over the button.
|
||||||
|
|
||||||
|
#### setBadgeText()
|
||||||
|
The text in a form of a badge over the button.
|
||||||
|
Used by **AdBlock** plugin to show how many item it blocked.
|
||||||
|
|
||||||
|
**Note:** When I set the badgeText in \__init__() it did not show in UI.
|
||||||
|
Maybe bug, maybe intentional behaviour, ask the Falkon author.
|
||||||
|
|
||||||
|
#### clicked event
|
||||||
|
Emitted when the mouse click on the button.
|
||||||
|
In this example this signal is connected to `onClicked()` method
|
||||||
|
|
||||||
|
#### onClicked()
|
||||||
|
The variable number is increased and its value is shown in the button badge.
|
||||||
|
|
||||||
|
|
||||||
|
## Plugin module
|
||||||
|
|
||||||
|
*\__init__.py*
|
||||||
|
|
||||||
|
```python
|
||||||
|
import Falkon
|
||||||
|
from PySide2 import QtCore
|
||||||
|
from Tutorial3.TutorialButton import TutorialButton
|
||||||
|
|
||||||
|
|
||||||
|
class Tutorial3_Plugin(Falkon.PluginInterface, QtCore.QObject):
|
||||||
|
def init(self, state, settingsPath):
|
||||||
|
self.buttons = {}
|
||||||
|
|
||||||
|
plugins = Falkon.MainApplication.instance().plugins()
|
||||||
|
|
||||||
|
plugins.mainWindowCreated.connect(self.mainWindowCreated)
|
||||||
|
plugins.mainWindowDeleted.connect(self.mainWindowDeleted)
|
||||||
|
|
||||||
|
if state == Falkon.PluginInterface.LateInitState:
|
||||||
|
for window in Falkon.MainApplication.instance().windows():
|
||||||
|
self.mainWindowCreated(window)
|
||||||
|
|
||||||
|
def unload(self):
|
||||||
|
for window in Falkon.MainApplication.instance().windows():
|
||||||
|
self.mainWindowDeleted(window)
|
||||||
|
|
||||||
|
def testPlugin(self):
|
||||||
|
return True
|
||||||
|
|
||||||
|
def mainWindowCreated(self, window):
|
||||||
|
b = TutorialButton()
|
||||||
|
window.navigationBar().addToolButton(b)
|
||||||
|
self.buttons[window] = b
|
||||||
|
|
||||||
|
def mainWindowDeleted(self, window):
|
||||||
|
if window not in self.buttons:
|
||||||
|
return
|
||||||
|
|
||||||
|
b = self.buttons[window]
|
||||||
|
window.navigationBar().removeToolButton(b)
|
||||||
|
del self.buttons[window]
|
||||||
|
|
||||||
|
|
||||||
|
Falkon.registerPlugin(Tutorial3_Plugin())
|
||||||
|
```
|
||||||
|
|
||||||
|
To add a button to the Falkon interface we need to create new button for each window and store it somewhere.
|
||||||
|
|
||||||
|
To add button to each window we create `mainWindowCreated()` and `mainWindowDeleted()` methods.
|
||||||
|
|
||||||
|
```python
|
||||||
|
def mainWindowCreated(self, window):
|
||||||
|
b = TutorialButton() # Create an instance of the button
|
||||||
|
window.navigationBar().addToolButton(b) # Add button to toolbar
|
||||||
|
self.buttons[window] = b # store the button
|
||||||
|
|
||||||
|
def mainWindowDeleted(self, window):
|
||||||
|
if window not in self.buttons: # Check if the button exist for selected window
|
||||||
|
return
|
||||||
|
|
||||||
|
b = self.buttons[window]
|
||||||
|
window.navigationBar().removeToolButton(b) # remove the button from toolbar
|
||||||
|
del self.buttons[window]
|
||||||
|
```
|
||||||
|
|
||||||
|
When the methods are ready we connect them to `mainWindowCreated` and `mainWindowDeleted` event.
|
||||||
|
|
||||||
|
```python
|
||||||
|
plugins = Falkon.MainApplication.instance().plugins()
|
||||||
|
|
||||||
|
plugins.mainWindowCreated.connect(self.mainWindowCreated)
|
||||||
|
plugins.mainWindowDeleted.connect(self.mainWindowDeleted)
|
||||||
|
```
|
||||||
|
|
||||||
|
Variable `plugins` is an instance of [PluginProxy](https://github.com/KDE/falkon/blob/master/src/lib/plugins/pluginproxy.h).
|
||||||
|
|
||||||
|
In case the extension is enabled when Falkon is already running we need to manually call `mainWindowCreated` method for each window.
|
||||||
|
|
||||||
|
```python
|
||||||
|
if state == Falkon.PluginInterface.LateInitState:
|
||||||
|
for window in Falkon.MainApplication.instance().windows(): # Get list of currently open windows
|
||||||
|
self.mainWindowCreated(window)
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
## Add button to statusbar
|
||||||
|
At the moment of writing this tutorial Falkon does not have any kind of configuration dialog to arrange buttons.
|
||||||
|
Buttons in statusbar are shown on 'first come first served' basis.
|
||||||
|
|
||||||
|
To add button to statusbar only two lines are needed.
|
||||||
|
|
||||||
|
### Update mainWindowCreated()
|
||||||
|
|
||||||
|
The line which needs to be added:
|
||||||
|
|
||||||
|
```python
|
||||||
|
window.statusBar().addButton(b)
|
||||||
|
```
|
||||||
|
|
||||||
|
### Update mainWindowDeleted()
|
||||||
|
|
||||||
|
The line which needs to be added:
|
||||||
|
|
||||||
|
```python
|
||||||
|
window.statusBar().removeButton(b)
|
||||||
|
```
|
||||||
|
|
||||||
|
### The result
|
||||||
|
|
||||||
|
```python
|
||||||
|
def mainWindowCreated(self, window):
|
||||||
|
b = TutorialButton()
|
||||||
|
window.navigationBar().addToolButton(b)
|
||||||
|
window.statusBar().addButton(b) # For statusbar
|
||||||
|
self.buttons[window] = b
|
||||||
|
|
||||||
|
def mainWindowDeleted(self, window):
|
||||||
|
if window not in self.buttons:
|
||||||
|
return
|
||||||
|
|
||||||
|
b = self.buttons[window]
|
||||||
|
window.navigationBar().removeToolButton(b)
|
||||||
|
window.statusBar().removeButton(b) # For statusbar
|
||||||
|
del self.buttons[window]
|
||||||
|
```
|
||||||
|
|
||||||
|
It is simple, right ?
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
[1]: https://github.com/KDE/falkon/blob/master/src/lib/tools/abstractbuttoninterface.h
|
44
extensions/Tutorial3/TutorialButton.py
Normal file
44
extensions/Tutorial3/TutorialButton.py
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
"""
|
||||||
|
# ============================================================
|
||||||
|
# Falkon Python Tutorial 3 - plugin for Falkon
|
||||||
|
# Copyright (C) 2019 Juraj Oravec <sgd.orava@gmail.com>
|
||||||
|
#
|
||||||
|
# This program is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation, either version 3 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
# ============================================================
|
||||||
|
"""
|
||||||
|
|
||||||
|
import Falkon
|
||||||
|
|
||||||
|
|
||||||
|
class TutorialButton(Falkon.AbstractButtonInterface):
|
||||||
|
def __init__(self):
|
||||||
|
super().__init__()
|
||||||
|
|
||||||
|
self.number = 0
|
||||||
|
|
||||||
|
self.setTitle("Tutorial 3")
|
||||||
|
self.setToolTip("Increment the number")
|
||||||
|
self.setBadgeText(str())
|
||||||
|
|
||||||
|
self.clicked.connect(self.onClicked)
|
||||||
|
|
||||||
|
def id(self):
|
||||||
|
return "falkon-python-tutorial-3-button"
|
||||||
|
|
||||||
|
def name(self):
|
||||||
|
return "Falkon Python Tutorial 3 Button"
|
||||||
|
|
||||||
|
def onClicked(self, controller):
|
||||||
|
self.number += 1
|
||||||
|
self.setBadgeText(str(self.number))
|
60
extensions/Tutorial3/__init__.py
Normal file
60
extensions/Tutorial3/__init__.py
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
"""
|
||||||
|
# ============================================================
|
||||||
|
# Falkon Python Tutorial 3 - plugin for Falkon
|
||||||
|
# Copyright (C) 2019 Juraj Oravec <sgd.orava@gmail.com>
|
||||||
|
#
|
||||||
|
# This program is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation, either version 3 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
# ============================================================
|
||||||
|
"""
|
||||||
|
|
||||||
|
import Falkon
|
||||||
|
from PySide2 import QtCore
|
||||||
|
from Tutorial3.TutorialButton import TutorialButton
|
||||||
|
|
||||||
|
|
||||||
|
class Tutorial3_Plugin(Falkon.PluginInterface, QtCore.QObject):
|
||||||
|
def init(self, state, settingsPath):
|
||||||
|
self.buttons = {}
|
||||||
|
|
||||||
|
plugins = Falkon.MainApplication.instance().plugins()
|
||||||
|
|
||||||
|
plugins.mainWindowCreated.connect(self.mainWindowCreated)
|
||||||
|
plugins.mainWindowDeleted.connect(self.mainWindowDeleted)
|
||||||
|
|
||||||
|
if state == Falkon.PluginInterface.LateInitState:
|
||||||
|
for window in Falkon.MainApplication.instance().windows():
|
||||||
|
self.mainWindowCreated(window)
|
||||||
|
|
||||||
|
def unload(self):
|
||||||
|
for window in Falkon.MainApplication.instance().windows():
|
||||||
|
self.mainWindowDeleted(window)
|
||||||
|
|
||||||
|
def testPlugin(self):
|
||||||
|
return True
|
||||||
|
|
||||||
|
def mainWindowCreated(self, window):
|
||||||
|
b = TutorialButton()
|
||||||
|
window.navigationBar().addToolButton(b)
|
||||||
|
self.buttons[window] = b
|
||||||
|
|
||||||
|
def mainWindowDeleted(self, window):
|
||||||
|
if window not in self.buttons:
|
||||||
|
return
|
||||||
|
|
||||||
|
b = self.buttons[window]
|
||||||
|
window.navigationBar().removeToolButton(b)
|
||||||
|
del self.buttons[window]
|
||||||
|
|
||||||
|
|
||||||
|
Falkon.registerPlugin(Tutorial3_Plugin())
|
11
extensions/Tutorial3/metadata.desktop
Normal file
11
extensions/Tutorial3/metadata.desktop
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
[Desktop Entry]
|
||||||
|
Name=Falkon Python Tutorial 3
|
||||||
|
Comment=Adding a button to the toolbar
|
||||||
|
Icon=
|
||||||
|
Type=Service
|
||||||
|
X-Falkon-Type=Extension/Python
|
||||||
|
|
||||||
|
X-Falkon-Author=Juraj Oravec
|
||||||
|
X-Falkon-Email=sgd.orava@gmail.com
|
||||||
|
X-Falkon-Version=1.0.0
|
||||||
|
X-Falkon-Settings=false
|
Loading…
Reference in New Issue
Block a user