Fix for bug 13274. Rework mouse events so that subframe capturing works...
[WebKit-https.git] / WebCore / platform / PopupMenu.h
index 7fa7089..85019d8 100644 (file)
 #include <wtf/PassRefPtr.h>
 
 #if PLATFORM(MAC)
-#include "RetainPtr.h"
+#include <wtf/RetainPtr.h>
 #ifdef __OBJC__
 @class NSPopUpButtonCell;
 #else
 class NSPopUpButtonCell;
 #endif
 #elif PLATFORM(WIN)
+#include "ScrollBar.h"
+#include <wtf/RefPtr.h>
 typedef struct HWND__* HWND;
 typedef struct HDC__* HDC;
 typedef struct HBITMAP__* HBITMAP;
 #elif PLATFORM(QT)
-#include <QHash>
-class QMenu;
-class QListWidgetItem;
+namespace WebCore {
+    class QWebPopup;
+}
 #endif
 
 namespace WebCore {
 
 class FrameView;
+class PlatformScrollbar;
 
-class PopupMenu : public Shared<PopupMenu> {
+class PopupMenu : public Shared<PopupMenu>
+#if PLATFORM(WIN)
+                , private ScrollbarClient
+#endif
+{
 public:
     static PassRefPtr<PopupMenu> create(PopupMenuClient* client) { return new PopupMenu(client); }
     ~PopupMenu();
@@ -63,6 +70,8 @@ public:
     PopupMenuClient* client() const { return m_popupClient; }
 
 #if PLATFORM(WIN)
+    PlatformScrollbar* scrollBar() const { return m_scrollBar.get(); }
+
     bool up(unsigned lines = 1);
     bool down(unsigned lines = 1);
 
@@ -70,9 +79,11 @@ public:
     const IntRect& windowRect() const { return m_windowRect; }
     IntRect clientRect() const;
 
-    int listIndexAtPoint(const IntPoint& point) { return (point.y() + m_scrollOffset) / m_itemHeight; }
+    int visibleItems() const;
 
-    bool setFocusedIndex(int index, bool hotTracking = false, bool fireOnChange = false);
+    int listIndexAtPoint(const IntPoint&) const;
+
+    bool setFocusedIndex(int index, bool hotTracking = false);
     int focusedIndex() const;
     void focusFirst();
     void focusLast();
@@ -87,16 +98,24 @@ public:
     void setScrollOffset(int offset) { m_scrollOffset = offset; }
     int scrollOffset() const { return m_scrollOffset; }
 
-    bool scrollTo(int);
     bool scrollToRevealSelection();
 
     void incrementWheelDelta(int delta);
     void reduceWheelDelta(int delta);
     int wheelDelta() const { return m_wheelDelta; }
+
+    bool scrollbarCapturingMouse() const { return m_scrollbarCapturingMouse; }
+    void setScrollbarCapturingMouse(bool b) { m_scrollbarCapturingMouse = b; }
 #endif
 
 protected:
     PopupMenu(PopupMenuClient* client);
+
+#if PLATFORM(WIN)
+    // ScrollBarClient
+    virtual void valueChanged(Scrollbar*);
+    virtual IntRect windowClipRect() const;
+#endif
     
 private:
     PopupMenuClient* m_popupClient;
@@ -109,12 +128,12 @@ private:
 #elif PLATFORM(QT)
     void clear();
     void populate(const IntRect&);
-    QMenu* m_popup;
-    QHash<QListWidgetItem*, int> m_actions;
+    QWebPopup* m_popup;
 #elif PLATFORM(WIN)
     void calculatePositionAndSize(const IntRect&, FrameView*);
     void invalidateItem(int index);
 
+    RefPtr<PlatformScrollbar> m_scrollBar;
     HWND m_popup;
     HDC m_DC;
     HBITMAP m_bmp;
@@ -123,6 +142,8 @@ private:
     int m_itemHeight;
     int m_scrollOffset;
     int m_wheelDelta;
+    int m_focusedIndex;
+    bool m_scrollbarCapturingMouse;
 #endif
 
 };