#include <QClipboard>
#include <QGraphicsSceneMouseEvent>
#include <QPersistentModelIndex>
+#include <QWebView>
#include "chatitem.h"
#include "chatline.h"
const qreal minContentsWidth = 200;
-class ClearWebPreviewEvent : public QEvent {
+class ChatScene::ClearWebPreviewEvent : public QEvent {
public:
- inline ClearWebPreviewEvent() : QEvent(QEvent::User) {}
+ inline ClearWebPreviewEvent() : QEvent((QEvent::Type)ChatScene::ClearWebPreviewEventType) {}
};
ChatScene::ChatScene(QAbstractItemModel *model, const QString &idString, qreal width, QObject *parent)
webPreview.delayTimer.setSingleShot(true);
connect(&webPreview.delayTimer, SIGNAL(timeout()), this, SLOT(showWebPreview()));
+
+ // installEventFilter(this);
+ // setItemIndexMethod(QGraphicsScene::NoIndex);
}
ChatScene::~ChatScene() {
if(atBottom || (!atTop && !moveTop)) {
emit lastLineChanged(_lines.last(), h);
}
-
}
void ChatScene::rowsAboutToBeRemoved(const QModelIndex &parent, int start, int end) {
void ChatScene::updateSceneRect(const QRectF &rect) {
_sceneRect = rect;
setSceneRect(rect);
+ update();
}
void ChatScene::customEvent(QEvent *event) {
- if(event->type() != QEvent::User)
+ switch(event->type()) {
+ case ClearWebPreviewEventType:
+ clearWebPreviewEvent((ClearWebPreviewEvent *)event);
+ break;
+ default:
return;
-
- event->accept();
- clearWebPreviewEvent();
+ }
}
void ChatScene::loadWebPreview(ChatItem *parentItem, const QString &url, const QRectF &urlRect) {
#endif
}
-void ChatScene::clearWebPreviewEvent() {
+void ChatScene::clearWebPreviewEvent(ClearWebPreviewEvent *event) {
#ifdef HAVE_WEBKIT
+ event->accept();
if(webPreview.previewItem) {
if(webPreview.previewItem->scene()) {
removeItem(webPreview.previewItem);
webPreview.urlRect = QRectF();
#endif
}
+
+bool ChatScene::eventFilter(QObject *watched, QEvent *event) {
+ qDebug() << watched << event;
+ return false;
+}
+