blob: 3688e815caa64a69fff976d7dbc2afbc50a9f1f7 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
|
/*
* SPDX-FileCopyrightText: 2008 Konstantin Heil <[email protected]>
*
* SPDX-License-Identifier: GPL-2.0-or-later
*/
#ifndef TOOLTIPMANAGER_H
#define TOOLTIPMANAGER_H
#include <KFileItem>
#include <QObject>
#include <QRect>
class DolphinFileMetaDataWidget;
class KToolTipWidget;
class QTimer;
class QWindow;
/**
* @brief Manages the tooltips for an item view.
*
* When hovering an item, a tooltip is shown after
* a short timeout. The tooltip is hidden again when the
* viewport is hovered or the item view has been left.
*/
class ToolTipManager : public QObject
{
Q_OBJECT
public:
enum class HideBehavior {
Instantly,
Later
};
explicit ToolTipManager(QWidget* parent);
~ToolTipManager() override;
/**
* Triggers the showing of the tooltip for the item \p item
* where the item has the maximum boundaries of \p itemRect.
* The tooltip manager takes care that the tooltip is shown
* slightly delayed and with a proper \p transientParent.
*/
void showToolTip(const KFileItem& item, const QRectF& itemRect, QWindow *transientParent);
/**
* Hides the currently shown tooltip.
*/
void hideToolTip(const HideBehavior behavior = HideBehavior::Later);
Q_SIGNALS:
/**
* Is emitted when the user clicks a tag or a link
* in the metadata widget.
*/
void urlActivated(const QUrl& url);
private Q_SLOTS:
void startContentRetrieval();
void setPreviewPix(const KFileItem& item, const QPixmap& pix);
void previewFailed();
void slotMetaDataRequestFinished();
void showToolTip();
private:
/// Timeout from requesting a tooltip until the tooltip
/// should be shown
QTimer* m_showToolTipTimer;
/// Timeout from requesting a tooltip until the retrieving of
/// the tooltip content like preview and meta data gets started.
QTimer* m_contentRetrievalTimer;
/// Transient parent of the tooltip, mandatory on Wayland.
QWindow* m_transientParent;
QScopedPointer<KToolTipWidget> m_tooltipWidget;
QScopedPointer<DolphinFileMetaDataWidget> m_fileMetaDataWidget;
bool m_toolTipRequested;
bool m_metaDataRequested;
bool m_appliedWaitCursor;
int m_margin;
KFileItem m_item;
QRect m_itemRect;
};
#endif
|