MsgId myMsgId = myIdx.data(MessageModel::MsgIdRole).value<MsgId>();
Message::Flags flags = (Message::Flags)myIdx.data(MessageModel::FlagsRole).toInt();
- // don't show the marker if we wrote that new line
- if(!(flags & Message::Self)) {
+ if(chatView()->isMarkerLineVisible()) {
BufferId bufferId = BufferId(chatScene()->idString().toInt());
MsgId lastSeenMsgId = Client::networkModel()->markerLineMsgId(bufferId);
if(lastSeenMsgId < myMsgId && lastSeenMsgId >= prevMsgId) {
_bufferContainer = 0;
_currentScaleFactor = 1;
_invalidateFilter = false;
+ _markerLineVisible = true;
+ _markedLine = 0;
setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
setVerticalScrollBarPolicy(Qt::ScrollBarAsNeeded);
connect(verticalScrollBar(), SIGNAL(valueChanged(int)), this, SLOT(verticalScrollbarChanged(int)));
_lastScrollbarPos = verticalScrollBar()->value();
+ connect(Client::networkModel(), SIGNAL(markerLineSet(BufferId,MsgId)), SLOT(markerLineSet(BufferId,MsgId)));
+
// only connect if client is synched with a core
if(Client::isConnected())
connect(Client::ignoreListManager(), SIGNAL(ignoreListChanged()), this, SLOT(invalidateFilter()));
return 0;
}
+void ChatView::setMarkerLineVisible(bool visible) {
+ if(visible != _markerLineVisible) {
+ _markerLineVisible = visible;
+ }
+}
+
+void ChatView::setMarkedLine(ChatLine *line) {
+ if(_markedLine == line)
+ return;
+
+ if(!scene()->isSingleBufferScene())
+ return;
+
+ if(line) {
+ BufferId bufId = scene()->singleBufferId();
+ Client::setMarkerLine(bufId, line->msgId());
+ }
+}
+
+void ChatView::markerLineSet(BufferId buffer, MsgId msg) {
+ if(!scene()->isSingleBufferScene() || scene()->singleBufferId() != buffer)
+ return;
+
+ ChatLine *newLine = scene()->chatLine(msg);
+ if(_markedLine == newLine)
+ return;
+
+ ChatLine *oldLine = _markedLine;
+ _markedLine = newLine;
+
+ if(oldLine)
+ oldLine->update();
+
+ if(newLine) {
+ setMarkerLineVisible(true);
+ newLine->update();
+ }
+}
+
void ChatView::addActionsToMenu(QMenu *menu, const QPointF &pos) {
// zoom actions
BufferWidget *bw = qobject_cast<BufferWidget *>(bufferContainer());
virtual bool event(QEvent *event);
+ inline bool isMarkerLineVisible() const { return _markerLineVisible; }
+ inline ChatLine *markedLine() const { return _markedLine; }
+
public slots:
inline virtual void clear() {}
void zoomIn();
void zoomOut();
void zoomOriginal();
+ void setMarkerLineVisible(bool visible = true);
+ void setMarkedLine(ChatLine *line);
+
protected:
virtual void resizeEvent(QResizeEvent *event);
void mouseMoveWhileSelecting(const QPointF &scenePos);
void scrollTimerTimeout();
void invalidateFilter();
+ void markerLineSet(BufferId buffer, MsgId msg);
private:
void init(MessageFilter *filter);
QTimer _scrollTimer;
int _scrollOffset;
bool _invalidateFilter;
+ bool _markerLineVisible;
+ ChatLine *_markedLine;
};