m_progressBar = new QProgressBar(this);
m_progressBar->hide();
- const QSize size(m_progressBar->sizeHint());
- const int barHeight = size.height();
+ const int contentHeight = QFontMetrics(m_messageLabel->font()).height() + 4;
+ const int barHeight = contentHeight + 4;
- m_progressBar->setMaximumWidth(200);
setMinimumHeight(barHeight);
m_messageLabel->setMinimumTextHeight(barHeight);
- m_spaceInfo->setFixedHeight(barHeight);
-
- connect(parent, SIGNAL(urlChanged(const KUrl&)),
- this, SLOT(updateSpaceInfoContent(const KUrl&)));
+ m_spaceInfo->setFixedHeight(contentHeight);
+ m_progressBar->setFixedHeight(contentHeight);
+ m_progressBar->setMaximumWidth(200);
}
DolphinStatusBar::~DolphinStatusBar()
-{}
+{
+}
void DolphinStatusBar::setMessage(const QString& msg,
Type type)
m_progressBar->setValue(m_progress);
if (!m_progressBar->isVisible() || (percent == 100)) {
- QTimer::singleShot(500, this, SLOT(updateProgressInfo()));
+ QTimer::singleShot(300, this, SLOT(updateProgressInfo()));
}
const QString& defaultText = m_messageLabel->defaultText();
void DolphinStatusBar::resizeEvent(QResizeEvent* event)
{
QWidget::resizeEvent(event);
- QTimer::singleShot(0, this, SLOT(showSpaceInfo()));
+ QMetaObject::invokeMethod(this, "showSpaceInfo", Qt::QueuedConnection);
}
void DolphinStatusBar::updateProgressInfo()
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)) {
+ // The space information is shown currently. Hide it if
+ // the status bar text does not fit into the available width.
+ if (widthGap > 0) {
m_spaceInfo->hide();
}
- } else if (widthGap + m_spaceInfo->width() <= 0) {
+ } else if (!isProgressBarVisible && (widthGap + m_spaceInfo->width() <= 0)) {
m_spaceInfo->show();
}
}