Source code for openlp.core.lib.settingstab

# -*- coding: utf-8 -*-
# vim: autoindent shiftwidth=4 expandtab textwidth=120 tabstop=4 softtabstop=4

###############################################################################
# OpenLP - Open Source Lyrics Projection                                      #
# --------------------------------------------------------------------------- #
# Copyright (c) 2008-2017 OpenLP Developers                                   #
# --------------------------------------------------------------------------- #
# 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                          #
###############################################################################
"""
The :mod:`~openlp.core.lib.settingstab` module contains the base SettingsTab class which plugins use for adding their
own tab to the settings dialog.
"""


from PyQt5 import QtWidgets


from openlp.core.common import RegistryProperties


[docs]class SettingsTab(QtWidgets.QWidget, RegistryProperties): """ SettingsTab is a helper widget for plugins to define Tabs for the settings dialog. """ def __init__(self, parent, title, visible_title=None, icon_path=None): """ Constructor to create the Settings tab item. :param parent: :param title: The title of the tab, which is used internally for the tab handling. :param visible_title: The title of the tab, which is usually displayed on the tab. :param icon_path: """ super(SettingsTab, self).__init__(parent) self.tab_title = title self.tab_title_visible = visible_title self.settings_section = self.tab_title.lower() self.tab_visited = False if icon_path: self.icon_path = icon_path self._setup() def _setup(self): """ Run some initial setup. This method is separate from __init__ in order to mock it out in tests. """ self.setupUi() self.retranslateUi() self.initialise() self.load()
[docs] def setupUi(self): """ Setup the tab's interface. """ self.tab_layout = QtWidgets.QHBoxLayout(self) self.tab_layout.setObjectName('tab_layout') self.left_column = QtWidgets.QWidget(self) self.left_column.setObjectName('left_column') self.left_layout = QtWidgets.QVBoxLayout(self.left_column) self.left_layout.setContentsMargins(0, 0, 0, 0) self.left_layout.setObjectName('left_layout') self.tab_layout.addWidget(self.left_column) self.right_column = QtWidgets.QWidget(self) self.right_column.setObjectName('right_column') self.right_layout = QtWidgets.QVBoxLayout(self.right_column) self.right_layout.setContentsMargins(0, 0, 0, 0) self.right_layout.setObjectName('right_layout') self.tab_layout.addWidget(self.right_column)
[docs] def resizeEvent(self, event=None): """ Resize the sides in two equal halves if the layout allows this. """ if event: QtWidgets.QWidget.resizeEvent(self, event) width = self.width() - self.tab_layout.spacing() - \ self.tab_layout.contentsMargins().left() - self.tab_layout.contentsMargins().right() left_width = min(width - self.right_column.minimumSizeHint().width(), width // 2) left_width = max(left_width, self.left_column.minimumSizeHint().width()) self.left_column.setFixedWidth(left_width)
[docs] def retranslateUi(self): """ Setup the interface translation strings. """ pass
[docs] def initialise(self): """ Do any extra initialisation here. """ pass
[docs] def load(self): """ Load settings from disk. """ pass
[docs] def save(self): """ Save settings to disk. """ pass
[docs] def cancel(self): """ Reset any settings if cancel triggered """ self.load()
[docs] def post_set_up(self, post_update=False): """ Changes which need to be made after setup of application :param post_update: Indicates if called before or after updates. """ pass
[docs] def tab_visible(self): """ Tab has just been made visible to the user """ pass