#include "tooltipmanager.h"
+#include "dolphintooltip.h"
#include "dolphinmodel.h"
#include "dolphinsortfilterproxymodel.h"
-#include <kformattedballoontipdelegate.h>
#include <kicon.h>
#include <ktooltip.h>
#include <QTimer>
#include <QToolTip>
-K_GLOBAL_STATIC(KFormattedBalloonTipDelegate, g_delegate)
+K_GLOBAL_STATIC(DolphinBalloonTooltipDelegate, g_delegate)
ToolTipManager::ToolTipManager(QAbstractItemView* parent,
DolphinSortFilterProxyModel* model) :
void ToolTipManager::showToolTip()
{
- KToolTipItem* tip = new KToolTipItem(KIcon(m_item.iconName()), m_item.getToolTipText());
+ // TODO - create tip during requestTip(...) - this makes it more likely that the previews
+ // job will have completed by the time the tooltip is shown, resulting in less flicker.
+ // The memory management will be more intricate, though.
+ DolphinToolTipItem *tip = new DolphinToolTipItem(m_item);
KStyleOptionToolTip option;
// TODO: get option content from KToolTip or add KToolTip::sizeHint() method
option.decorationSize = QSize(32, 32);
const QSize size = g_delegate->sizeHint(&option, tip);
- const QRect desktop = QApplication::desktop()->availableGeometry();
+ const QRect desktop = QApplication::desktop()->screenGeometry(m_itemRect.bottomRight());
// m_itemRect defines the area of the item, where the tooltip should be
// shown. Per default the tooltip is shown in the bottom right corner.
// - the content is not drawn inside m_itemRect
int x = m_itemRect.right();
int y = m_itemRect.bottom();
- const int xDiff = x + size.width() - desktop.width();
- const int yDiff = y + size.height() - desktop.height();
-
- if ((xDiff > 0) && (yDiff > 0)) {
+ // TODO: handle usecase if x or y get smaller than the
+ // desktop-left or the desktop-top
+ if (x + size.width() - 1 > desktop.right()) {
x = m_itemRect.left() - size.width();
+ }
+ if (y + size.height() - 1 > desktop.bottom()) {
y = m_itemRect.top() - size.height();
- } else if (xDiff > 0) {
- x -= xDiff;
- } else if (yDiff > 0) {
- y -= yDiff;
}
-
KToolTip::showTip(QPoint(x, y), tip);
}