X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fchatitem.cpp;h=97853250bdff8f374bc0644c47cf2d9d651ea927;hp=fcdbca49ec9baeecf7859e1b6240349fbea79a8b;hb=7c78f651ee68ac7f9028f9a3640d4c8ae808c826;hpb=7e76b93191c8f19c24709f36992c99f8ee9d508d diff --git a/src/qtui/chatitem.cpp b/src/qtui/chatitem.cpp index fcdbca49..97853250 100644 --- a/src/qtui/chatitem.cpp +++ b/src/qtui/chatitem.cpp @@ -463,6 +463,16 @@ QList ContentsChatItem::findClickables() const { return result; } +ContentsChatItem::Clickable ContentsChatItem::clickableAt(const QPointF &pos) const { + qint16 idx = posToCursor(pos); + for(int i = 0; i < privateData()->clickables.count(); i++) { + Clickable click = privateData()->clickables.at(i); + if(idx >= click.start && idx < click.start + click.length) + return click; + } + return Clickable(); +} + QVector ContentsChatItem::additionalFormats() const { // mark a clickable if hovered upon QVector fmt; @@ -490,7 +500,7 @@ void ContentsChatItem::endHoverMode() { void ContentsChatItem::handleClick(const QPointF &pos, ChatScene::ClickMode clickMode) { if(clickMode == ChatScene::SingleClick) { - Clickable click = privateData()->currentClickable; + Clickable click = clickableAt(pos); if(click.isValid()) { QString str = data(ChatLineModel::DisplayRole).toString().mid(click.start, click.length); switch(click.type) { @@ -509,7 +519,7 @@ void ContentsChatItem::handleClick(const QPointF &pos, ChatScene::ClickMode clic } else if(clickMode == ChatScene::DoubleClick) { chatScene()->setSelectingItem(this); setSelectionMode(PartialSelection); - Clickable click = privateData()->currentClickable; + Clickable click = clickableAt(pos); if(click.isValid()) { setSelectionStart(click.start); setSelectionEnd(click.start + click.length); @@ -543,23 +553,20 @@ void ContentsChatItem::hoverLeaveEvent(QGraphicsSceneHoverEvent *event) { void ContentsChatItem::hoverMoveEvent(QGraphicsSceneHoverEvent *event) { bool onClickable = false; - qint16 idx = posToCursor(event->pos()); - for(int i = 0; i < privateData()->clickables.count(); i++) { - Clickable click = privateData()->clickables.at(i); - if(idx >= click.start && idx < click.start + click.length) { - if(click.type == Clickable::Url) { - onClickable = true; - showWebPreview(click); - } else if(click.type == Clickable::Channel) { - // TODO: don't make clickable if it's our own name - // onClickable = true; //FIXME disabled for now - } - if(onClickable) { - setCursor(Qt::PointingHandCursor); - privateData()->currentClickable = click; - update(); - break; - } + Clickable click = clickableAt(event->pos()); + if(click.isValid()) { + if(click.type == Clickable::Url) { + onClickable = true; + showWebPreview(click); + } else if(click.type == Clickable::Channel) { + // TODO: don't make clickable if it's our own name + // onClickable = true; //FIXME disabled for now + } + if(onClickable) { + setCursor(Qt::PointingHandCursor); + privateData()->currentClickable = click; + update(); + return; } } if(!onClickable) endHoverMode();