X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/50676d8d255ed52d91885e5dd23e60474777cfd5..abf17941f7:/src/dolphinstatusbar.cpp diff --git a/src/dolphinstatusbar.cpp b/src/dolphinstatusbar.cpp index a112a1f64..26a373875 100644 --- a/src/dolphinstatusbar.cpp +++ b/src/dolphinstatusbar.cpp @@ -52,12 +52,15 @@ DolphinStatusBar::DolphinStatusBar(DolphinView* parent) : m_progressBar->hide(); const QSize size(m_progressBar->sizeHint()); + const int barHeight = size.height(); + m_progressBar->setMaximumWidth(200); - setMinimumHeight(size.height()); - m_messageLabel->setMinimumTextHeight(size.height()); + setMinimumHeight(barHeight); + m_messageLabel->setMinimumTextHeight(barHeight); + m_spaceInfo->setFixedHeight(barHeight); connect(parent, SIGNAL(urlChanged(const KUrl&)), - this, SLOT(updateSpaceInfo(const KUrl&))); + this, SLOT(updateSpaceInfoContent(const KUrl&))); } @@ -68,19 +71,14 @@ DolphinStatusBar::~DolphinStatusBar() void DolphinStatusBar::setMessage(const QString& msg, Type type) { - m_messageLabel->setText(msg); - m_messageLabel->setType(type); + m_messageLabel->setMessage(msg, type); - if (type == Error) { - // assure that enough space is available for the error message and - // hide the space information and progress information - m_spaceInfo->hide(); + const int widthGap = m_messageLabel->widthGap(); + if (widthGap > 0) { m_progressBar->hide(); m_progressText->hide(); } - else if (!m_progressBar->isVisible()) { - m_spaceInfo->show(); - } + showSpaceInfo(); } DolphinStatusBar::Type DolphinStatusBar::type() const @@ -124,25 +122,35 @@ void DolphinStatusBar::setProgress(int percent) 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) +{ + QWidget::resizeEvent(event); + QTimer::singleShot(0, this, SLOT(showSpaceInfo())); } void DolphinStatusBar::updateProgressInfo() @@ -160,15 +168,33 @@ void DolphinStatusBar::updateProgressInfo() // hide the progress information and show the space information m_progressText->hide(); m_progressBar->hide(); - if (m_messageLabel->type() != Error) { - m_spaceInfo->show(); - } + showSpaceInfo(); } } -void DolphinStatusBar::updateSpaceInfo(const KUrl& url) +void DolphinStatusBar::updateSpaceInfoContent(const KUrl& url) { m_spaceInfo->setUrl(url); + showSpaceInfo(); +} + +void DolphinStatusBar::showSpaceInfo() +{ + const int widthGap = m_messageLabel->widthGap(); + const bool isProgressBarVisible = m_progressBar->isVisible(); + + if (m_spaceInfo->isVisible()) { + // The space information is shown currently. Hide it + // if the progress bar is visible or if the status bar + // text does not fit into the available width. + const QSize size(m_progressBar->sizeHint()); + if (isProgressBarVisible || (widthGap > 0)) { + m_spaceInfo->hide(); + } + } + else if (widthGap + m_spaceInfo->width() <= 0) { + m_spaceInfo->show(); + } } #include "dolphinstatusbar.moc"