mirror of https://gitlab.com/openlp/openlp.git
42 lines
2.5 KiB
Python
42 lines
2.5 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
##########################################################################
|
|
# OpenLP - Open Source Lyrics Projection #
|
|
# ---------------------------------------------------------------------- #
|
|
# Copyright (c) 2008-2022 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, 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 <https://www.gnu.org/licenses/>. #
|
|
##########################################################################
|
|
"""
|
|
Forms in OpenLP are made up of two classes. One class holds all the graphical elements, like buttons and lists, and the
|
|
other class holds all the functional code, like slots and loading and saving.
|
|
|
|
The first class, commonly known as the **Dialog** class, is typically named ``Ui_<name>Dialog``. It is a slightly
|
|
modified version of the class that the ``pyuic5`` command produces from Qt5's .ui file. Typical modifications will be
|
|
converting most strings from "" to '' and using OpenLP's ``translate()`` function for translating strings.
|
|
|
|
The second class, commonly known as the **Form** class, is typically named ``<name>Form``. This class is the one which
|
|
is instantiated and used. It uses dual inheritance to inherit from (usually) QtWidgets.QDialog and the Ui class
|
|
mentioned above, like so::
|
|
|
|
class AuthorsForm(QtWidgets.QDialog, Ui_AuthorsDialog):
|
|
|
|
def __init__(self, parent=None):
|
|
super(AuthorsForm, self).__init__(parent)
|
|
self.setup_ui(self)
|
|
|
|
This allows OpenLP to use ``self.object`` for all the GUI elements while keeping them separate from the functionality,
|
|
so that it is easier to recreate the GUI from the .ui files later if necessary.
|
|
"""
|