X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fchatitem.h;h=b6e8a9cf70b62933077467426a846d2f27879fac;hp=c5bb53335af2d3bb7f3c9cfcca09ea6e517dd6af;hb=03d6711ea69594e8a4637b4ea20baeb9a109af9c;hpb=57d9abdd9cb8506a12f4a2dbb96fd8d840c380c8 diff --git a/src/qtui/chatitem.h b/src/qtui/chatitem.h index c5bb5333..b6e8a9cf 100644 --- a/src/qtui/chatitem.h +++ b/src/qtui/chatitem.h @@ -197,11 +197,50 @@ struct ContentsChatItem::Clickable { }; struct ContentsChatItemPrivate : ChatItemPrivate { + ContentsChatItem *contentsItem; QList clickables; ContentsChatItem::Clickable currentClickable; bool hasDragged; - ContentsChatItemPrivate(QTextLayout *l, const QList &c) : ChatItemPrivate(l), clickables(c), hasDragged(false) {} + ContentsChatItemPrivate(QTextLayout *l, const QList &c, ContentsChatItem *parent) : ChatItemPrivate(l), contentsItem(parent), clickables(c), hasDragged(false), controller(0) {} + ~ContentsChatItemPrivate(); + + void loadWebPreview(const QString &url, const QRectF &urlRect); + void clearPreview(); + +private: + class PreviewController; + class PreviewItem; + PreviewController *controller; +}; + +class ContentsChatItemPrivate::PreviewController : public QObject { + Q_OBJECT +public: + PreviewController(ContentsChatItem *contentsItem) : contentsItem(contentsItem), previewItem(0) {} + ~PreviewController(); + + void loadPage(const QString &url, const QRectF &urlRect); + +private slots: + void pageLoaded(bool success); + +private: + ContentsChatItem *contentsItem; + ContentsChatItemPrivate::PreviewItem *previewItem; + + QString url; +}; + +class QWebView; +class ContentsChatItemPrivate::PreviewItem : public QGraphicsItem { +public: + PreviewItem(QWebView *webView); + virtual void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget = 0); + virtual inline QRectF boundingRect() const { return _boundingRect; } + +private: + QRectF _boundingRect; }; //inlines regarding ContentsChatItemPrivate