X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fchatitem.h;h=0710b6afaf47aea2a650c2af21a45cc468823810;hp=cf608cd4d3510c8921df0d7f24cce136771e0f7b;hb=f64ded9b73ed4eb09d3e2c14cddc0ead1e269185;hpb=61e0633ce94a38e669382c29db498f335d2e0fa8 diff --git a/src/qtui/chatitem.h b/src/qtui/chatitem.h index cf608cd4..0710b6af 100644 --- a/src/qtui/chatitem.h +++ b/src/qtui/chatitem.h @@ -58,12 +58,17 @@ public: QVariant data(int role) const; // selection stuff, to be called by the scene + QString selection() const; void clearSelection(); void setFullSelection(); void continueSelecting(const QPointF &pos); + bool hasSelection() const; + bool isPosOverSelection(const QPointF &pos) const; QList findWords(const QString &searchWord, Qt::CaseSensitivity caseSensitive); + virtual void handleClick(const QPointF &pos, ChatScene::ClickMode); + protected: virtual void mouseMoveEvent(QGraphicsSceneMouseEvent *event); virtual void mousePressEvent(QGraphicsSceneMouseEvent *event); @@ -74,7 +79,7 @@ protected: virtual QTextLayout::FormatRange selectionFormat() const; virtual inline QVector additionalFormats() const { return QVector(); } - qint16 posToCursor(const QPointF &pos); + qint16 posToCursor(const QPointF &pos) const; inline bool hasPrivateData() const { return (bool)_data; } ChatItemPrivate *privateData() const; @@ -167,13 +172,11 @@ public: protected: virtual void mouseMoveEvent(QGraphicsSceneMouseEvent *event); - virtual void mousePressEvent(QGraphicsSceneMouseEvent *event); - virtual void mouseReleaseEvent(QGraphicsSceneMouseEvent *event); virtual void hoverLeaveEvent(QGraphicsSceneHoverEvent *event); virtual void hoverMoveEvent(QGraphicsSceneHoverEvent *event); virtual void contextMenuEvent(QGraphicsSceneContextMenuEvent *event); - + virtual void handleClick(const QPointF &pos, ChatScene::ClickMode clickMode); virtual QVector additionalFormats() const; @@ -220,10 +223,9 @@ struct ContentsChatItemPrivate : ChatItemPrivate { ContentsChatItem *contentsItem; QList clickables; ContentsChatItem::Clickable currentClickable; - bool hasDragged; ContentsChatItemPrivate(QTextLayout *l, const QList &c, ContentsChatItem *parent) - : ChatItemPrivate(l), contentsItem(parent), clickables(c), hasDragged(false) {} + : ChatItemPrivate(l), contentsItem(parent), clickables(c) {} }; //inlines regarding ContentsChatItemPrivate