#pragma once
#include "MouseEventInit.h"
#include "MouseRelatedEvent.h"
namespace WebCore {
class DataTransfer;
class PlatformMouseEvent;
class MouseEvent : public MouseRelatedEvent {
public:
static Ref<MouseEvent> create(const AtomicString& type, bool canBubble, bool cancelable, double timestamp, DOMWindow*,
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, double force, unsigned short syntheticClickType);
WEBCORE_EXPORT static Ref<MouseEvent> create(const AtomicString& type, bool canBubble, bool cancelable, double timestamp, DOMWindow*,
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, double force, unsigned short syntheticClickType, PassRefPtr<DataTransfer>, bool isSimulated = false);
WEBCORE_EXPORT static Ref<MouseEvent> create(const AtomicString& eventType, DOMWindow*, const PlatformMouseEvent&, int detail, PassRefPtr<Node> relatedTarget);
static Ref<MouseEvent> create(const AtomicString& eventType, bool canBubble, bool cancelable, DOMWindow*,
int detail, int screenX, int screenY, int clientX, int clientY,
bool ctrlKey, bool altKey, bool shiftKey, bool metaKey,
unsigned short button, unsigned short syntheticClickType, PassRefPtr<EventTarget> relatedTarget);
static Ref<MouseEvent> createForBindings()
{
return adoptRef(*new MouseEvent);
}
static Ref<MouseEvent> create(const AtomicString& eventType, const MouseEventInit&, IsTrusted = IsTrusted::No);
virtual ~MouseEvent();
WEBCORE_EXPORT void initMouseEvent(const AtomicString& type, bool canBubble, bool cancelable, DOMWindow*,
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; }
unsigned short syntheticClickType() const { return m_syntheticClickType; }
bool buttonDown() const { return m_buttonDown; }
EventTarget* relatedTarget() const final { return m_relatedTarget.get(); }
void setRelatedTarget(PassRefPtr<EventTarget> relatedTarget) { m_relatedTarget = relatedTarget; }
double force() const { return m_force; }
void setForce(double force) { m_force = force; }
WEBCORE_EXPORT Node* toElement() const;
WEBCORE_EXPORT Node* fromElement() const;
DataTransfer* dataTransfer() const { return isDragEvent() ? m_dataTransfer.get() : nullptr; }
EventInterface eventInterface() const override;
bool isMouseEvent() const override;
bool isDragEvent() const override;
static bool canTriggerActivationBehavior(const Event&);
int which() const override;
Ref<Event> cloneFor(HTMLIFrameElement*) const override;
protected:
MouseEvent(const AtomicString& type, bool canBubble, bool cancelable, double timestamp, DOMWindow*,
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, double force, unsigned short syntheticClickType, PassRefPtr<DataTransfer>, bool isSimulated);
MouseEvent(const AtomicString& type, bool canBubble, bool cancelable, DOMWindow*,
int detail, int screenX, int screenY, int clientX, int clientY,
bool ctrlKey, bool altKey, bool shiftKey, bool metaKey,
unsigned short button, unsigned short syntheticClickType, PassRefPtr<EventTarget> relatedTarget);
MouseEvent(const AtomicString& type, const MouseEventInit&, IsTrusted);
MouseEvent();
private:
unsigned short m_button;
unsigned short m_syntheticClickType;
bool m_buttonDown;
RefPtr<EventTarget> m_relatedTarget;
double m_force { 0 };
RefPtr<DataTransfer> m_dataTransfer;
};
}
SPECIALIZE_TYPE_TRAITS_EVENT(MouseEvent)