void DolphinStatusBar::setMessage(const QString& msg,
Type type)
{
- m_messageLabel->setText(msg);
- m_messageLabel->setType(type);
+ m_messageLabel->setMessage(msg, type);
const int widthGap = m_messageLabel->widthGap();
if (widthGap > 0) {
QTimer::singleShot(500, this, SLOT(updateProgressInfo()));
}
+ const QString& defaultText = m_messageLabel->defaultText();
const QString msg(m_messageLabel->text());
if ((percent == 0) && !msg.isEmpty()) {
setMessage(QString::null, Default);
}
- else if ((percent == 100) && (msg != m_defaultText)) {
- setMessage(m_defaultText, Default);
+ else if ((percent == 100) && (msg != defaultText)) {
+ setMessage(defaultText, Default);
}
}
void DolphinStatusBar::clear()
{
- // TODO: check for timeout, so that it's prevented that
- // a message is cleared too early.
- setMessage(m_defaultText, Default);
+ setMessage(m_messageLabel->defaultText(), Default);
}
void DolphinStatusBar::setDefaultText(const QString& text)
{
- m_defaultText = text;
+ m_messageLabel->setDefaultText(text);
+}
+
+const QString& DolphinStatusBar::defaultText() const
+{
+ return m_messageLabel->defaultText();
}
void DolphinStatusBar::resizeEvent(QResizeEvent* event)
connect(m_timer, SIGNAL(timeout()),
this, SLOT(timerDone()));
- m_closeButton = new QPushButton(KIcon("close"), QString::null, this);
+ m_closeButton = new QPushButton(i18n("Close"), this);
m_closeButton->hide();
+ connect(m_closeButton, SIGNAL(clicked()),
+ this, SLOT(closeErrorMessage()));
}
StatusBarMessageLabel::~StatusBarMessageLabel()
{
}
-void StatusBarMessageLabel::setType(DolphinStatusBar::Type type)
+void StatusBarMessageLabel::setMessage(const QString& text,
+ DolphinStatusBar::Type type)
{
- if ((type != m_type) || (type == DolphinStatusBar::Error)) {
- m_type = type;
-
- m_timer->stop();
- m_illumination = 0;
- m_state = Default;
-
- const char* iconName = 0;
- QPixmap pixmap;
- switch (type) {
- case DolphinStatusBar::OperationCompleted:
- iconName = "ok";
- m_closeButton->hide();
- break;
-
- case DolphinStatusBar::Information:
- iconName = "info";
- m_closeButton->hide();
- break;
-
- case DolphinStatusBar::Error:
- iconName = "error";
- m_timer->start(100);
- m_state = Illuminate;
-
- updateCloseButtonPosition();
- m_closeButton->show();
- break;
-
- case DolphinStatusBar::Default:
- default:
- m_closeButton->hide();
- break;
+ if (m_type == DolphinStatusBar::Error) {
+ // If an error is shown currently, other error messages get queued.
+ // Non-error messages are ignored if there are pending error messages.
+ if (type == DolphinStatusBar::Error) {
+ m_pendingMessages.append(text);
+ return;
}
+ if ((m_state != Default) || !m_pendingMessages.isEmpty()) {
+ return;
+ }
+ }
- m_pixmap = (iconName == 0) ? QPixmap() : SmallIcon(iconName);
- QTimer::singleShot(GeometryTimeout, this, SLOT(assureVisibleText()));
- update();
+ if ((text == m_text) && (type == m_type)) {
+ return;
}
-}
-void StatusBarMessageLabel::setText(const QString& text)
-{
- if (text != m_text) {
- if (m_type == DolphinStatusBar::Error) {
+ m_text = text;
+ m_type = type;
+
+ m_timer->stop();
+ m_illumination = 0;
+ m_state = Default;
+
+ const char* iconName = 0;
+ QPixmap pixmap;
+ switch (type) {
+ case DolphinStatusBar::OperationCompleted:
+ iconName = "ok";
+ m_closeButton->hide();
+ break;
+
+ case DolphinStatusBar::Information:
+ iconName = "info";
+ m_closeButton->hide();
+ break;
+
+ case DolphinStatusBar::Error:
+ iconName = "error";
m_timer->start(100);
- m_illumination = 0;
m_state = Illuminate;
- }
- m_text = text;
- QTimer::singleShot(GeometryTimeout, this, SLOT(assureVisibleText()));
- update();
+
+ updateCloseButtonPosition();
+ m_closeButton->show();
+ break;
+
+ case DolphinStatusBar::Default:
+ default:
+ m_closeButton->hide();
+ break;
}
+
+ m_pixmap = (iconName == 0) ? QPixmap() : SmallIcon(iconName);
+ QTimer::singleShot(GeometryTimeout, this, SLOT(assureVisibleText()));
+ update();
}
void StatusBarMessageLabel::setMinimumTextHeight(int min)
if (min != m_minTextHeight) {
m_minTextHeight = min;
setMinimumHeight(min);
+ m_closeButton->setFixedHeight(min - borderGap() * 2);
}
}
void StatusBarMessageLabel::resizeEvent(QResizeEvent* event)
{
QWidget::resizeEvent(event);
+ updateCloseButtonPosition();
QTimer::singleShot(GeometryTimeout, this, SLOT(assureVisibleText()));
}
{
const int buttonWidth = (m_type == DolphinStatusBar::Error) ?
m_closeButton->width() + borderGap() : 0;
- return width() - m_pixmap.width() - (borderGap() * 3) - buttonWidth;
+ return width() - m_pixmap.width() - (borderGap() * 4) - buttonWidth;
}
QColor StatusBarMessageLabel::mixColors(const QColor& c1,
void StatusBarMessageLabel::updateCloseButtonPosition()
{
- const int x = width() - m_closeButton->width();
- const int y = 2;
+ const int x = width() - m_closeButton->width() - borderGap();
+ const int y = height() - m_closeButton->height() - borderGap();
m_closeButton->move(x, y);
}
+void StatusBarMessageLabel::closeErrorMessage()
+{
+ if (!showPendingMessage()) {
+ reset();
+ setMessage(m_defaultText, DolphinStatusBar::Default);
+ }
+}
+
+bool StatusBarMessageLabel::showPendingMessage()
+{
+ if (!m_pendingMessages.isEmpty()) {
+ reset();
+ setMessage(m_pendingMessages.takeFirst(), DolphinStatusBar::Error);
+ return true;
+ }
+ return false;
+}
+
+void StatusBarMessageLabel::reset()
+{
+ m_text = QString::null;
+ m_type = DolphinStatusBar::Default;
+}
+
#include "statusbarmessagelabel.moc"
#include <dolphinstatusbar.h>
+#include <QList>
#include <QPixmap>
#include <QString>
#include <QWidget>
explicit StatusBarMessageLabel(QWidget* parent);
virtual ~StatusBarMessageLabel();
- void setType(DolphinStatusBar::Type type);
- DolphinStatusBar::Type type() const { return m_type; }
+ void setMessage(const QString& text, DolphinStatusBar::Type type);
- void setText(const QString& text);
+ DolphinStatusBar::Type type() const { return m_type; }
const QString& text() const { return m_text; }
+ void setDefaultText(const QString& text) { m_defaultText = text; }
+ const QString& defaultText() const { return m_defaultText; }
+
// TODO: maybe a better approach is possible with the size hint
void setMinimumTextHeight(int min);
int minimumTextHeight() const { return m_minTextHeight; }
*/
void updateCloseButtonPosition();
+ /**
+ * Closes the currently shown error message and replaces it
+ * by the next pending message.
+ */
+ void closeErrorMessage();
+
+private:
+ /**
+ * Shows the next pending error message. If no pending message
+ * was in the queue, false is returned.
+ */
+ bool showPendingMessage();
+
+ /**
+ * Resets the message label properties. This is useful when the
+ * result of invoking StatusBarMessageLabel::setMessage() should
+ * not rely on previous states.
+ */
+ void reset();
+
private:
enum State {
Default,
int m_minTextHeight;
QTimer* m_timer;
QString m_text;
+ QString m_defaultText;
+ QList<QString> m_pendingMessages;
QPixmap m_pixmap;
QPushButton* m_closeButton;
const QColor& c2,
int percent) const;
- int borderGap() const { return 3; }
+ int borderGap() const { return 2; }
};
#endif