openlp/openlp/core/lib/settingstab.py

134 lines
4.8 KiB
Python
Raw Normal View History

# -*- coding: utf-8 -*-
# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
###############################################################################
# OpenLP - Open Source Lyrics Projection #
# --------------------------------------------------------------------------- #
2010-12-26 11:04:47 +00:00
# Copyright (c) 2008-2011 Raoul Snyman #
# Portions copyright (c) 2008-2011 Tim Bentley, Jonathan Corwin, Michael #
2011-03-24 19:04:02 +00:00
# Gorven, Scott Guerrieri, Matthias Hub, Meinert Jordan, Armin Köhler, #
# Andreas Preikschat, Mattias Põldaru, Christian Richter, Philip Ridout, #
# Maikel Stuivenberg, Martin Thompson, Jon Tibble, Frode Woldsund #
# --------------------------------------------------------------------------- #
# 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; version 2 of the License. #
# #
# 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, write to the Free Software Foundation, Inc., 59 #
# Temple Place, Suite 330, Boston, MA 02111-1307 USA #
###############################################################################
2009-09-25 00:43:42 +00:00
from PyQt4 import QtGui
class SettingsTab(QtGui.QWidget):
"""
2009-07-10 13:16:15 +00:00
SettingsTab is a helper widget for plugins to define Tabs for the settings
dialog.
"""
2011-04-13 19:12:47 +00:00
def __init__(self, parent, title, visible_title=None, icon_path=None):
"""
2009-07-10 13:16:15 +00:00
Constructor to create the Settings tab item.
``title``
The title of the tab, which is used internally for the tab handling.
``visible_title``
The title of the tab, which is usually displayed on the tab.
"""
2011-04-13 19:12:47 +00:00
QtGui.QWidget.__init__(self, parent)
self.tabTitle = title
self.tabTitleVisible = visible_title
self.settingsSection = self.tabTitle.lower()
2011-04-12 17:45:32 +00:00
if icon_path:
self.icon_path = icon_path
self.setupUi()
self.retranslateUi()
2009-05-01 11:50:09 +00:00
self.initialise()
2010-04-02 18:12:54 +00:00
self.preLoad()
self.load()
def setupUi(self):
2009-05-01 11:50:09 +00:00
"""
Setup the tab's interface.
"""
self.tabLayout = QtGui.QHBoxLayout(self)
self.tabLayout.setObjectName(u'tabLayout')
self.leftColumn = QtGui.QWidget(self)
self.leftColumn.setObjectName(u'leftColumn')
self.leftLayout = QtGui.QVBoxLayout(self.leftColumn)
self.leftLayout.setMargin(0)
self.leftLayout.setObjectName(u'leftLayout')
self.tabLayout.addWidget(self.leftColumn)
self.rightColumn = QtGui.QWidget(self)
self.rightColumn.setObjectName(u'rightColumn')
self.rightLayout = QtGui.QVBoxLayout(self.rightColumn)
self.rightLayout.setMargin(0)
self.rightLayout.setObjectName(u'rightLayout')
self.tabLayout.addWidget(self.rightColumn)
def resizeEvent(self, event=None):
"""
Resize the sides in two equal halves if the layout allows this.
"""
if event:
QtGui.QWidget.resizeEvent(self, event)
width = self.width() - self.tabLayout.spacing() - \
self.tabLayout.contentsMargins().left() - \
self.tabLayout.contentsMargins().right()
left_width = min(width - self.rightColumn.minimumSizeHint().width(),
width / 2)
left_width = max(left_width, self.leftColumn.minimumSizeHint().width())
self.leftColumn.setFixedWidth(left_width)
2010-04-02 18:12:54 +00:00
def preLoad(self):
"""
Setup the tab's interface.
"""
pass
def retranslateUi(self):
2009-05-01 11:50:09 +00:00
"""
Setup the interface translation strings.
"""
pass
def initialise(self):
"""
Do any extra initialisation here.
"""
pass
def load(self):
2009-05-01 11:50:09 +00:00
"""
Load settings from disk.
"""
pass
def save(self):
2009-05-01 11:50:09 +00:00
"""
Save settings to disk.
"""
pass
2009-08-29 07:17:56 +00:00
def cancel(self):
"""
Reset any settings
"""
pass
2010-12-02 14:37:38 +00:00
def postSetUp(self, postUpdate=False):
2009-08-29 07:17:56 +00:00
"""
Changes which need to be made after setup of application
2010-12-02 14:37:38 +00:00
``postUpdate``
Indicates if called before or after updates.
2009-08-29 07:17:56 +00:00
"""
pass