Summary:
BUG: 420027
BUG: 422226
FIXED-IN: 20.08
Test Plan: {
F8312398}
Reviewers: #dolphin, ngraham, broulik, #vdg, elvisangelaccio
Reviewed By: #dolphin, ngraham, #vdg, elvisangelaccio
Subscribers: elvisangelaccio, kfm-devel
Tags: #dolphin
Differential Revision: https://phabricator.kde.org/D29213
void DolphinStatusBar::setUrl(const QUrl& url)
{
void DolphinStatusBar::setUrl(const QUrl& url)
{
- m_spaceInfo->setUrl(url);
+ if (GeneralSettings::showSpaceInfo()) {
+ m_spaceInfo->setUrl(url);
+ }
}
QUrl DolphinStatusBar::url() const
}
QUrl DolphinStatusBar::url() const
showSpaceInfo = GeneralSettings::showSpaceInfo();
showZoomSlider = GeneralSettings::showZoomSlider();
}
showSpaceInfo = GeneralSettings::showSpaceInfo();
showZoomSlider = GeneralSettings::showZoomSlider();
}
- m_spaceInfo->setVisible(showSpaceInfo);
+ m_spaceInfo->setShown(showSpaceInfo);
m_zoomSlider->setVisible(showZoomSlider);
}
m_zoomSlider->setVisible(showZoomSlider);
}
SpaceInfoObserver::SpaceInfoObserver(const QUrl& url, QObject* parent) :
QObject(parent),
m_mountPointObserver(nullptr),
SpaceInfoObserver::SpaceInfoObserver(const QUrl& url, QObject* parent) :
QObject(parent),
m_mountPointObserver(nullptr),
m_dataSize(0),
m_dataAvailable(0)
{
m_dataSize(0),
m_dataAvailable(0)
{
void SpaceInfoObserver::spaceInfoChanged(quint64 size, quint64 available)
{
// Make sure that the size has actually changed
void SpaceInfoObserver::spaceInfoChanged(quint64 size, quint64 available)
{
// Make sure that the size has actually changed
- if (m_dataSize != size || m_dataAvailable != available) {
+ if (m_dataSize != size || m_dataAvailable != available || !m_hasData) {
+ m_hasData = true;
m_dataSize = size;
m_dataAvailable = available;
m_dataSize = size;
m_dataAvailable = available;
private:
MountPointObserver* m_mountPointObserver;
private:
MountPointObserver* m_mountPointObserver;
quint64 m_dataSize;
quint64 m_dataAvailable;
};
quint64 m_dataSize;
quint64 m_dataAvailable;
};
+void StatusBarSpaceInfo::setShown(bool shown)
+{
+ m_shown = shown;
+ if (!m_shown) {
+ hide();
+ m_ready = false;
+ }
+}
+
void StatusBarSpaceInfo::setUrl(const QUrl& url)
{
if (m_url != url) {
m_url = url;
void StatusBarSpaceInfo::setUrl(const QUrl& url)
{
if (m_url != url) {
m_url = url;
- m_observer->setUrl(url);
+ m_observer.reset(new SpaceInfoObserver(m_url, this));
+ connect(m_observer.data(), &SpaceInfoObserver::valuesChanged, this, &StatusBarSpaceInfo::slotValuesChanged);
void StatusBarSpaceInfo::showEvent(QShowEvent* event)
{
void StatusBarSpaceInfo::showEvent(QShowEvent* event)
{
- KCapacityBar::showEvent(event);
- m_observer.reset(new SpaceInfoObserver(m_url, this));
- slotValuesChanged();
- connect(m_observer.data(), &SpaceInfoObserver::valuesChanged, this, &StatusBarSpaceInfo::slotValuesChanged);
+ if (m_shown) {
+ if (m_ready) {
+ KCapacityBar::showEvent(event);
+ }
+
+ if (m_observer.isNull()) {
+ m_observer.reset(new SpaceInfoObserver(m_url, this));
+ connect(m_observer.data(), &SpaceInfoObserver::valuesChanged, this, &StatusBarSpaceInfo::slotValuesChanged);
+ }
+ }
}
void StatusBarSpaceInfo::hideEvent(QHideEvent* event)
{
}
void StatusBarSpaceInfo::hideEvent(QHideEvent* event)
{
+ if (m_ready) {
+ m_observer.reset();
+ m_ready = false;
+ }
KCapacityBar::hideEvent(event);
}
KCapacityBar::hideEvent(event);
}
{
Q_ASSERT(m_observer);
const quint64 size = m_observer->size();
{
Q_ASSERT(m_observer);
const quint64 size = m_observer->size();
- if (size == 0) {
- setText(i18nc("@info:status", "Unknown size"));
- setValue(0);
- update();
+
+ if (!m_shown || size == 0) {
+ hide();
+ return;
+ }
+
+ m_ready = true;
+
+ const quint64 available = m_observer->available();
+ const quint64 used = size - available;
+ const int percentUsed = qRound(100.0 * qreal(used) / qreal(size));
+
+ setText(i18nc("@info:status Free disk space", "%1 free", KIO::convertSize(available)));
+ setUpdatesEnabled(false);
+ setValue(percentUsed);
+ setUpdatesEnabled(true);
+
+ if (!isVisible()) {
+ show();
- const quint64 available = m_observer->available();
- const quint64 used = size - available;
- const int percentUsed = qRound(100.0 * qreal(used) / qreal(size));
-
- setText(i18nc("@info:status Free disk space", "%1 free", KIO::convertSize(available)));
- setUpdatesEnabled(false);
- setValue(percentUsed);
- setUpdatesEnabled(true);
explicit StatusBarSpaceInfo(QWidget* parent = nullptr);
~StatusBarSpaceInfo() override;
explicit StatusBarSpaceInfo(QWidget* parent = nullptr);
~StatusBarSpaceInfo() override;
+ /**
+ * Use this to set the widget visibility as it can hide itself
+ */
+ void setShown(bool);
void setUrl(const QUrl& url);
QUrl url() const;
void setUrl(const QUrl& url);
QUrl url() const;
private:
QScopedPointer<SpaceInfoObserver> m_observer;
QUrl m_url;
private:
QScopedPointer<SpaceInfoObserver> m_observer;
QUrl m_url;
+ bool m_ready;
+ bool m_shown;