X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fchatitem.h;h=3cb9c3d754dd2c4b440b7c6b8a85ebf4e3138ed5;hp=79f8720e416a43fcc4e5e35fec894e802a3ba4fd;hb=eacb532f13295a30fa4366a6ff29d1168db84280;hpb=229b87f259ab1bc2c65f481eb39c25a872080fe7 diff --git a/src/qtui/chatitem.h b/src/qtui/chatitem.h index 79f8720e..3cb9c3d7 100644 --- a/src/qtui/chatitem.h +++ b/src/qtui/chatitem.h @@ -58,25 +58,42 @@ 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: + enum SelectionMode { + NoSelection, + PartialSelection, + FullSelection + }; + virtual void mouseMoveEvent(QGraphicsSceneMouseEvent *event); virtual void mousePressEvent(QGraphicsSceneMouseEvent *event); virtual void mouseReleaseEvent(QGraphicsSceneMouseEvent *event); - //virtual bool handleClick(ClickMode mode); - inline QTextLayout *layout() const; virtual QTextLayout::FormatRange selectionFormat() const; virtual inline QVector additionalFormats() const { return QVector(); } - qint16 posToCursor(const QPointF &pos); + inline qint16 selectionStart() const { return _selectionStart; } + inline void setSelectionStart(qint16 start) { _selectionStart = start; } + inline qint16 selectionEnd() const { return _selectionEnd; } + inline void setSelectionEnd(qint16 end) { _selectionEnd = end; } + inline SelectionMode selectionMode() const { return _selectionMode; } + inline void setSelectionMode(SelectionMode mode) { _selectionMode = mode; } + void setSelection(SelectionMode mode, qint16 selectionStart, qint16 selectionEnd); + + qint16 posToCursor(const QPointF &pos) const; inline bool hasPrivateData() const { return (bool)_data; } ChatItemPrivate *privateData() const; @@ -103,7 +120,6 @@ private: ChatItemPrivate *_data; QRectF _boundingRect; - enum SelectionMode { NoSelection, PartialSelection, FullSelection }; SelectionMode _selectionMode; qint16 _selectionStart, _selectionEnd; @@ -169,13 +185,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; @@ -222,14 +236,15 @@ 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 -ChatItemPrivate *ContentsChatItem::newPrivateData() { return new ContentsChatItemPrivate(createLayout(QTextOption::WrapAnywhere), findClickables(), this); } +ChatItemPrivate *ContentsChatItem::newPrivateData() { + return new ContentsChatItemPrivate(createLayout(QTextOption::WrapAnywhere), findClickables(), this); +} ContentsChatItemPrivate *ContentsChatItem::privateData() const { return (ContentsChatItemPrivate *)ChatItem::privateData(); } class ContentsChatItem::WrapColumnFinder {