diff options
| author | David Hallas <[email protected]> | 2019-03-17 19:13:05 +0100 |
|---|---|---|
| committer | David Hallas <[email protected]> | 2019-03-17 19:13:05 +0100 |
| commit | bbfa6c4473b8278ce7636ca18dd3ad417f4c4cdb (patch) | |
| tree | 700f86cfee50637a4798e752b196454636d9b56a /src/views/tooltips/tooltipmanager.cpp | |
| parent | f2b72c164888bce6dcdec343fd832a98f5837be1 (diff) | |
| parent | 508dc815c75c9db8abaec26ae664ae41bf7f89b5 (diff) | |
Merge remote-tracking branch 'origin/Applications/19.04'
Diffstat (limited to 'src/views/tooltips/tooltipmanager.cpp')
| -rw-r--r-- | src/views/tooltips/tooltipmanager.cpp | 19 |
1 files changed, 17 insertions, 2 deletions
diff --git a/src/views/tooltips/tooltipmanager.cpp b/src/views/tooltips/tooltipmanager.cpp index 9e79a8f70..2990f4249 100644 --- a/src/views/tooltips/tooltipmanager.cpp +++ b/src/views/tooltips/tooltipmanager.cpp @@ -25,6 +25,7 @@ #include <KIO/PreviewJob> #include <KJobWidgets> #include <KToolTipWidget> +#include <KIconLoader> #include <QApplication> #include <QDesktopWidget> @@ -34,6 +35,15 @@ #include <QTimer> #include <QWindow> +class IconLoaderSingleton { +public: + IconLoaderSingleton() = default; + + KIconLoader self; +}; + +Q_GLOBAL_STATIC(IconLoaderSingleton, iconLoader) + ToolTipManager::ToolTipManager(QWidget* parent) : QObject(parent), m_showToolTipTimer(nullptr), @@ -167,8 +177,13 @@ void ToolTipManager::previewFailed() if (!m_toolTipRequested) { return; } - - const QPixmap pixmap = QIcon::fromTheme(m_item.iconName()).pixmap(128, 128); + QPalette pal; + for (auto state : { QPalette::Active, QPalette::Inactive, QPalette::Disabled }) { + pal.setBrush(state, QPalette::WindowText, pal.toolTipText()); + pal.setBrush(state, QPalette::Window, pal.toolTipBase()); + } + iconLoader->self.setCustomPalette(pal); + const QPixmap pixmap = KDE::icon(m_item.iconName(), &iconLoader->self).pixmap(128, 128); m_fileMetaDataWidget->setPreview(pixmap); if (!m_showToolTipTimer->isActive()) { showToolTip(); |
