_bufferContainer = 0;
_currentScaleFactor = 1;
_invalidateFilter = false;
- _markerLineVisible = true;
- _markedLine = 0;
setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
setVerticalScrollBarPolicy(Qt::ScrollBarAsNeeded);
return result;
}
-ChatLine *ChatView::lastVisibleChatLine() const {
+ChatLine *ChatView::lastVisibleChatLine(bool ignoreDayChange) const {
if(!scene())
return 0;
QSet<ChatLine *> visibleLines = visibleChatLines(Qt::ContainsItemBoundingRect);
foreach(ChatLine *line, visibleLines) {
- if(line->row() > row)
+ if(line->row() > row && (ignoreDayChange? line->msgType() != Message::DayChange : true))
row = line->row();
}
}
void ChatView::setMarkerLineVisible(bool visible) {
- if(visible != _markerLineVisible) {
- _markerLineVisible = visible;
- }
+ scene()->setMarkerLineVisible(visible);
}
-void ChatView::setMarkedLine(ChatLine *line) {
- if(_markedLine == line)
- return;
-
+void ChatView::setMarkerLine(MsgId msgId) {
if(!scene()->isSingleBufferScene())
return;
- if(line) {
- BufferId bufId = scene()->singleBufferId();
- Client::setMarkerLine(bufId, line->msgId());
- }
+ BufferId bufId = scene()->singleBufferId();
+ Client::setMarkerLine(bufId, msgId);
}
-void ChatView::markerLineSet(BufferId buffer, MsgId msg) {
+void ChatView::markerLineSet(BufferId buffer, MsgId msgId) {
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();
+ scene()->setMarkerLine(msgId);
+ scene()->setMarkerLineVisible(true);
+}
- if(newLine) {
- setMarkerLineVisible(true);
- newLine->update();
- }
+void ChatView::jumpToMarkerLine(bool requestBacklog) {
+ scene()->jumpToMarkerLine(requestBacklog);
}
void ChatView::addActionsToMenu(QMenu *menu, const QPointF &pos) {