20#include "moc_qgsmessagebaritem.cpp"
26#include <QTextBrowser>
27#include <QDesktopServices>
34 , mDuration( duration )
44 , mDuration( duration )
54 , mDuration( duration )
56 , mUserIcon( QIcon() )
65 , mDuration( duration )
67 , mUserIcon( QIcon() )
73void QgsMessageBarItem::writeContent()
80 mLayout =
new QHBoxLayout(
this );
81 mLayout->setContentsMargins( 0, 0, 0, 0 );
82 mTextBrowser =
nullptr;
89 mLblIcon =
new QLabel(
this );
90 mLayout->addWidget( mLblIcon );
93 if ( !mUserIcon.isNull() )
99 QString msgIcon( QStringLiteral(
"/mIconInfo.svg" ) );
103 msgIcon = QStringLiteral(
"/mIconCritical.svg" );
106 msgIcon = QStringLiteral(
"/mIconWarning.svg" );
109 msgIcon = QStringLiteral(
"/mIconSuccess.svg" );
116 const int iconSize = std::max( 24.0, fontMetrics().height() * 1.2 );
117 mLblIcon->setPixmap(
icon.pixmap( iconSize ) );
121 QString contentStyleSheet;
124 mStyleSheet = QStringLiteral(
"QgsMessageBar { background-color: #dff0d8; border: 1px solid #8e998a; } "
125 "QLabel,QTextEdit { color: black; } " );
126 contentStyleSheet = QStringLiteral(
"<style> a, a:visited, a:hover { color:#268300; } </style>" );
130 mStyleSheet = QStringLiteral(
"QgsMessageBar { background-color: #d65253; border: 1px solid #9b3d3d; } "
131 "QLabel,QTextEdit { color: white; } " );
132 contentStyleSheet = QStringLiteral(
"<style>a, a:visited, a:hover { color:#4e0001; }</style>" );
136 mStyleSheet = QStringLiteral(
"QgsMessageBar { background-color: #ffc800; border: 1px solid #e0aa00; } "
137 "QLabel,QTextEdit { color: black; } " );
138 contentStyleSheet = QStringLiteral(
"<style>a, a:visited, a:hover { color:#945a00; }</style>" );
142 mStyleSheet = QStringLiteral(
"QgsMessageBar { background-color: #e7f5fe; border: 1px solid #b9cfe4; } "
143 "QLabel,QTextEdit { color: #2554a1; } " );
144 contentStyleSheet = QStringLiteral(
"<style>a, a:visited, a:hover { color:#3bb2fe; }</style>" );
146 mStyleSheet += QLatin1String(
"QLabel#mItemCount { font-style: italic; }" );
149 if ( mTitle.isEmpty() && mText.isEmpty() )
154 mTextBrowser =
nullptr;
161 mTextBrowser =
new QTextBrowser(
this );
162 mTextBrowser->setObjectName( QStringLiteral(
"textEdit" ) );
163 mTextBrowser->setSizePolicy( QSizePolicy::Expanding, QSizePolicy::Maximum );
164 mTextBrowser->setReadOnly(
true );
165 mTextBrowser->setOpenLinks(
false );
166 connect( mTextBrowser, &QTextBrowser::anchorClicked,
this, &QgsMessageBarItem::urlClicked );
168 mTextBrowser->setFrameShape( QFrame::NoFrame );
171 mTextBrowser->setStyleSheet(
"QTextEdit { background-color: rgba(0,0,0,0); margin-top: 0.25em; max-height: 1.75em; min-height: 1.75em; } "
172 "QScrollBar { background-color: rgba(0,0,0,0); } "
173 "QScrollBar::add-page,QScrollBar::sub-page,QScrollBar::handle { background-color: rgba(0,0,0,0); color: rgba(0,0,0,0); } "
174 "QScrollBar::up-arrow,QScrollBar::down-arrow { color: rgb(0,0,0); } " );
175 mLayout->addWidget( mTextBrowser );
177 QString content = mText;
178 if ( !mTitle.isEmpty() )
181 QString t = mTitle.trimmed();
182 if ( !content.isEmpty() && !t.endsWith(
':' ) && !t.endsWith( QLatin1String(
": " ) ) )
183 t += QLatin1String(
": " );
184 content.prepend( QStringLiteral(
"<b>" ) + t +
" </b>" );
186 content.prepend( contentStyleSheet );
187 mTextBrowser->setText( content );
193 QLayoutItem *item = mLayout->itemAt( 2 );
194 if ( !item || item->widget() != mWidget )
196 mLayout->addWidget( mWidget );
227 if (
level != mLevel )
246 QLayoutItem *item =
nullptr;
247 item = mLayout->itemAt( 2 );
248 if ( item->widget() == mWidget )
250 delete item->widget();
289void QgsMessageBarItem::urlClicked(
const QUrl &url )
291 const QFileInfo file( url.toLocalFile() );
292 if ( file.exists() && !file.isDir() )
295 QDesktopServices::openUrl( url );
MessageLevel
Level for messages This will be used both for message log and message bar in application.
@ Warning
Warning message.
@ Critical
Critical/error message.
@ Info
Information message.
@ Success
Used for reporting a successful operation.
static QIcon getThemeIcon(const QString &name, const QColor &fillColor=QColor(), const QColor &strokeColor=QColor())
Helper to get a theme icon.
static QgsNative * nativePlatformInterface()
Returns the global native interface, which offers abstraction to the host OS's underlying public inte...
Represents an item shown within a QgsMessageBar widget.
void styleChanged(const QString &styleSheet)
Emitted when the item's message level has changed and the message bar style will need to be updated a...
QIcon icon() const
Returns the icon for the message.
QgsMessageBarItem * setLevel(Qgis::MessageLevel level)
Sets the message level for the item, which controls how the message bar is styled when the item is di...
int duration() const
Returns the duration (in seconds) of the message.
QgsMessageBarItem * setText(const QString &text)
Sets the message text to show in the item.
QgsMessageBarItem * setIcon(const QIcon &icon)
Sets the icon associated with the message.
QString text() const
Returns the text for the message.
QWidget * widget() const
Returns the widget for the message.
QgsMessageBarItem(const QString &text, Qgis::MessageLevel level=Qgis::MessageLevel::Info, int duration=0, QWidget *parent=nullptr)
Constructor for QgsMessageBarItem, containing a message with the specified text to be displayed on th...
QString title() const
Returns the title for the message.
QgsMessageBarItem * setTitle(const QString &title)
Sets the title for in the item.
Qgis::MessageLevel level() const
Returns the message level for the message.
QgsMessageBarItem * setDuration(int duration)
Sets the duration (in seconds) to show the message for.
QgsMessageBarItem * setWidget(QWidget *widget)
Sets a custom widget to show in the item.
void dismiss()
Dismisses the item, removing it from the message bar and deleting it.
static int defaultMessageTimeout(Qgis::MessageLevel level=Qgis::MessageLevel::NoLevel)
Returns the default timeout in seconds for timed messages of the specified level.
bool popWidget(QgsMessageBarItem *item)
Remove the specified item from the bar, and display the next most recent one in the stack.
QSize iconSize(bool dockableToolbar)
Returns the user-preferred size of a window's toolbar icons.