#ifndef MouseEvent_h
#define MouseEvent_h
#include "MouseRelatedEvent.h"
namespace WebCore {
class DataTransfer;
class PlatformMouseEvent;
struct MouseEventInit : public UIEventInit {
MouseEventInit();
int screenX;
int screenY;
int clientX;
int clientY;
bool ctrlKey;
bool altKey;
bool shiftKey;
bool metaKey;
unsigned short button;
RefPtr<EventTarget> relatedTarget;
};
class MouseEvent : public MouseRelatedEvent {
public:
static PassRefPtr<MouseEvent> create()
{
return adoptRef(new MouseEvent);
}
static PassRefPtr<MouseEvent> create(const AtomicString& type, bool canBubble, bool cancelable, double timestamp, PassRefPtr<AbstractView>,
int detail, int screenX, int screenY, int pageX, int pageY,
#if ENABLE(POINTER_LOCK)
int movementX, int movementY,
#endif
bool ctrlKey, bool altKey, bool shiftKey, bool metaKey, unsigned short button,
PassRefPtr<EventTarget> relatedTarget);
static PassRefPtr<MouseEvent> create(const AtomicString& type, bool canBubble, bool cancelable, double timestamp, PassRefPtr<AbstractView>,
int detail, int screenX, int screenY, int pageX, int pageY,
#if ENABLE(POINTER_LOCK)
int movementX, int movementY,
#endif
bool ctrlKey, bool altKey, bool shiftKey, bool metaKey, unsigned short button,
PassRefPtr<EventTarget> relatedTarget, PassRefPtr<DataTransfer>, bool isSimulated = false);
static PassRefPtr<MouseEvent> create(const AtomicString& eventType, PassRefPtr<AbstractView>, const PlatformMouseEvent&, int detail, PassRefPtr<Node> relatedTarget);
static PassRefPtr<MouseEvent> create(const AtomicString& eventType, const MouseEventInit&);
virtual ~MouseEvent();
void initMouseEvent(const AtomicString& type, bool canBubble, bool cancelable, PassRefPtr<AbstractView>,
int detail, int screenX, int screenY, int clientX, int clientY,
bool ctrlKey, bool altKey, bool shiftKey, bool metaKey,
unsigned short button, PassRefPtr<EventTarget> relatedTarget);
unsigned short button() const { return m_button; }
bool buttonDown() const { return m_buttonDown; }
virtual EventTarget* relatedTarget() const override final { return m_relatedTarget.get(); }
void setRelatedTarget(PassRefPtr<EventTarget> relatedTarget) { m_relatedTarget = relatedTarget; }
Node* toElement() const;
Node* fromElement() const;
DataTransfer* dataTransfer() const { return isDragEvent() ? m_dataTransfer.get() : 0; }
virtual DataTransfer* internalDataTransfer() const override { return m_dataTransfer.get(); }
virtual EventInterface eventInterface() const override;
virtual bool isMouseEvent() const override;
virtual bool isDragEvent() const override;
virtual int which() const override;
virtual PassRefPtr<Event> cloneFor(HTMLIFrameElement*) const override;
protected:
MouseEvent(const AtomicString& type, bool canBubble, bool cancelable, double timestamp, PassRefPtr<AbstractView>,
int detail, int screenX, int screenY, int pageX, int pageY,
#if ENABLE(POINTER_LOCK)
int movementX, int movementY,
#endif
bool ctrlKey, bool altKey, bool shiftKey, bool metaKey, unsigned short button,
PassRefPtr<EventTarget> relatedTarget, PassRefPtr<DataTransfer>, bool isSimulated);
MouseEvent(const AtomicString& type, const MouseEventInit&);
MouseEvent();
private:
unsigned short m_button;
bool m_buttonDown;
RefPtr<EventTarget> m_relatedTarget;
RefPtr<DataTransfer> m_dataTransfer;
};
class SimulatedMouseEvent : public MouseEvent {
public:
static PassRefPtr<SimulatedMouseEvent> create(const AtomicString& eventType, PassRefPtr<AbstractView>, PassRefPtr<Event> underlyingEvent, Element* target);
virtual ~SimulatedMouseEvent();
private:
SimulatedMouseEvent(const AtomicString& eventType, PassRefPtr<AbstractView>, PassRefPtr<Event> underlyingEvent, Element* target);
};
EVENT_TYPE_CASTS(MouseEvent)
}
#endif // MouseEvent_h