1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108
|
# This file is part of the Frescobaldi project, http://www.frescobaldi.org/
#
# Copyright (c) 2008 - 2014 by Wilbert Berendsen
#
# 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 2
# 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, write to the Free Software
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
# See http://www.gnu.org/licenses/ for more information.
"""
Simple dialogs to ask input from the user.
"""
from PyQt5.QtCore import QSettings, Qt
from PyQt5.QtGui import QColor
from PyQt5.QtWidgets import QCompleter, QColorDialog, QWidget
import app
import widgets.dialog
import userguide
def getText(
parent = None,
title = "",
message = "",
text = "",
icon = None,
help = None,
validate = None,
regexp = None,
wordWrap = True,
complete = None,
):
"""Asks a string of text from the user.
Arguments:
parent: parent widget or None
title: dialog window title (without appname)
message: message, question
text: pre-entered text in the line edit
icon: which icon to show
help: help page or name
validate: a function that accepts text and returns whether it is valid.
regexp: a regular expression string. If given it provides an alternate
validation method using a QRegExpValidator.
wordWrap: whether to word-wrap the message text (default: True).
complete: a string list or QAbstractItemModel to provide completions.
"""
dlg = widgets.dialog.TextDialog(parent,
title=app.caption(title), message=message, icon=icon)
dlg.setText(text)
dlg.setMinimumWidth(320)
dlg.messageLabel().setWordWrap(wordWrap)
if help is not None:
userguide.addButton(dlg.buttonBox(), help)
dlg.setWindowModality(Qt.WindowModal)
else:
dlg.setWindowModality(Qt.ApplicationModal)
if regexp:
dlg.setValidateRegExp(regexp)
elif validate:
dlg.setValidateFunction(validate)
if complete:
c = QCompleter(complete, dlg.lineEdit())
dlg.lineEdit().setCompleter(c)
if dlg.exec_():
return dlg.text()
def getColor(
parent = None,
title = "",
color = None,
alpha = False,
):
"""Ask the user a color."""
global _savedColor
if color is None:
color = _savedColor
dlg = QColorDialog(color, parent)
options = QColorDialog.ColorDialogOptions()
if alpha:
options |= QColorDialog.ShowAlphaChannel
if not QSettings().value("native_dialogs/colordialog", True, bool):
options |= QColorDialog.DontUseNativeDialog
dlg.setOptions(options)
dlg.setWindowTitle(title or app.caption(_("Select Color")))
if dlg.exec_():
_savedColor = dlg.selectedColor()
return _savedColor
_savedColor = QColor(Qt.white)
|