Skip to content

Commit e584189

Browse files
bplaatkalenikaliaksandr
authored andcommitted
LibWeb: Reorder MouseEvent items to follow spec more
1 parent 824c54a commit e584189

File tree

6 files changed

+76
-68
lines changed

6 files changed

+76
-68
lines changed

Userland/Libraries/LibWeb/Page/EventHandler.cpp

Lines changed: 9 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -187,7 +187,9 @@ bool EventHandler::handle_mousewheel(CSSPixelPoint position, unsigned button, un
187187
return false;
188188

189189
auto offset = compute_mouse_event_offset(position, *layout_node);
190-
if (node->dispatch_event(UIEvents::WheelEvent::create_from_platform_event(node->realm(), UIEvents::EventNames::wheel, offset.x(), offset.y(), position.x(), position.y(), wheel_delta_x, wheel_delta_y, buttons, button).release_value_but_fixme_should_propagate_errors())) {
190+
auto client_offset = compute_mouse_event_client_offset(position);
191+
auto page_offset = compute_mouse_event_page_offset(client_offset);
192+
if (node->dispatch_event(UIEvents::WheelEvent::create_from_platform_event(node->realm(), UIEvents::EventNames::wheel, page_offset, client_offset, offset, wheel_delta_x, wheel_delta_y, button, buttons).release_value_but_fixme_should_propagate_errors())) {
191193
if (auto* page = m_browsing_context->page()) {
192194
if (m_browsing_context == &page->top_level_browsing_context())
193195
page->client().page_did_request_scroll(wheel_delta_x, wheel_delta_y);
@@ -248,15 +250,15 @@ bool EventHandler::handle_mouseup(CSSPixelPoint position, unsigned button, unsig
248250
auto offset = compute_mouse_event_offset(position, *layout_node);
249251
auto client_offset = compute_mouse_event_client_offset(position);
250252
auto page_offset = compute_mouse_event_page_offset(client_offset);
251-
node->dispatch_event(UIEvents::MouseEvent::create_from_platform_event(node->realm(), UIEvents::EventNames::mouseup, offset, client_offset, page_offset, {}, buttons, button).release_value_but_fixme_should_propagate_errors());
253+
node->dispatch_event(UIEvents::MouseEvent::create_from_platform_event(node->realm(), UIEvents::EventNames::mouseup, page_offset, client_offset, offset, {}, button, buttons).release_value_but_fixme_should_propagate_errors());
252254
handled_event = true;
253255

254256
bool run_activation_behavior = false;
255257
if (node.ptr() == m_mousedown_target) {
256258
if (button == GUI::MouseButton::Primary)
257-
run_activation_behavior = node->dispatch_event(UIEvents::MouseEvent::create_from_platform_event(node->realm(), UIEvents::EventNames::click, offset, client_offset, page_offset, {}, button).release_value_but_fixme_should_propagate_errors());
259+
run_activation_behavior = node->dispatch_event(UIEvents::MouseEvent::create_from_platform_event(node->realm(), UIEvents::EventNames::click, page_offset, client_offset, offset, {}, 1, button).release_value_but_fixme_should_propagate_errors());
258260
else if (button == GUI::MouseButton::Secondary && !(modifiers & Mod_Shift)) // Allow the user to bypass custom context menus by holding shift, like Firefox.
259-
run_activation_behavior = node->dispatch_event(UIEvents::MouseEvent::create_from_platform_event(node->realm(), UIEvents::EventNames::contextmenu, offset, client_offset, page_offset, {}, button).release_value_but_fixme_should_propagate_errors());
261+
run_activation_behavior = node->dispatch_event(UIEvents::MouseEvent::create_from_platform_event(node->realm(), UIEvents::EventNames::contextmenu, page_offset, client_offset, offset, {}, 1, button).release_value_but_fixme_should_propagate_errors());
260262
}
261263

262264
if (run_activation_behavior) {
@@ -384,7 +386,7 @@ bool EventHandler::handle_mousedown(CSSPixelPoint position, unsigned button, uns
384386
auto offset = compute_mouse_event_offset(position, *layout_node);
385387
auto client_offset = compute_mouse_event_client_offset(position);
386388
auto page_offset = compute_mouse_event_page_offset(client_offset);
387-
node->dispatch_event(UIEvents::MouseEvent::create_from_platform_event(node->realm(), UIEvents::EventNames::mousedown, offset, client_offset, page_offset, {}, buttons, button).release_value_but_fixme_should_propagate_errors());
389+
node->dispatch_event(UIEvents::MouseEvent::create_from_platform_event(node->realm(), UIEvents::EventNames::mousedown, page_offset, client_offset, offset, {}, button, buttons).release_value_but_fixme_should_propagate_errors());
388390
}
389391

390392
// NOTE: Dispatching an event may have disturbed the world.
@@ -498,7 +500,7 @@ bool EventHandler::handle_mousemove(CSSPixelPoint position, unsigned buttons, un
498500
auto client_offset = compute_mouse_event_client_offset(position);
499501
auto page_offset = compute_mouse_event_page_offset(client_offset);
500502
auto movement = compute_mouse_event_movement(client_offset);
501-
node->dispatch_event(UIEvents::MouseEvent::create_from_platform_event(node->realm(), UIEvents::EventNames::mousemove, offset, client_offset, page_offset, movement, buttons).release_value_but_fixme_should_propagate_errors());
503+
node->dispatch_event(UIEvents::MouseEvent::create_from_platform_event(node->realm(), UIEvents::EventNames::mousemove, page_offset, client_offset, offset, movement, 1, buttons).release_value_but_fixme_should_propagate_errors());
502504
m_mousemove_previous_client_offset = client_offset;
503505
// NOTE: Dispatching an event may have disturbed the world.
504506
if (!paint_root() || paint_root() != node->document().paintable_box())
@@ -584,7 +586,7 @@ bool EventHandler::handle_doubleclick(CSSPixelPoint position, unsigned button, u
584586
auto offset = compute_mouse_event_offset(position, *layout_node);
585587
auto client_offset = compute_mouse_event_client_offset(position);
586588
auto page_offset = compute_mouse_event_page_offset(client_offset);
587-
node->dispatch_event(UIEvents::MouseEvent::create_from_platform_event(node->realm(), UIEvents::EventNames::dblclick, offset, client_offset, page_offset, {}, buttons, button).release_value_but_fixme_should_propagate_errors());
589+
node->dispatch_event(UIEvents::MouseEvent::create_from_platform_event(node->realm(), UIEvents::EventNames::dblclick, page_offset, client_offset, offset, {}, button, buttons).release_value_but_fixme_should_propagate_errors());
588590

589591
// NOTE: Dispatching an event may have disturbed the world.
590592
if (!paint_root() || paint_root() != node->document().paintable_box())

Userland/Libraries/LibWeb/UIEvents/MouseEvent.cpp

Lines changed: 14 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -13,14 +13,16 @@
1313

1414
namespace Web::UIEvents {
1515

16-
MouseEvent::MouseEvent(JS::Realm& realm, FlyString const& event_name, MouseEventInit const& event_init)
16+
MouseEvent::MouseEvent(JS::Realm& realm, FlyString const& event_name, MouseEventInit const& event_init, double page_x, double page_y, double offset_x, double offset_y)
1717
: UIEvent(realm, event_name, event_init)
18-
, m_offset_x(event_init.offset_x)
19-
, m_offset_y(event_init.offset_y)
18+
, m_screen_x(event_init.screen_x)
19+
, m_screen_y(event_init.screen_y)
20+
, m_page_x(page_x)
21+
, m_page_y(page_y)
2022
, m_client_x(event_init.client_x)
2123
, m_client_y(event_init.client_y)
22-
, m_page_x(event_init.page_x)
23-
, m_page_y(event_init.page_y)
24+
, m_offset_x(offset_x)
25+
, m_offset_y(offset_y)
2426
, m_movement_x(event_init.movement_x)
2527
, m_movement_y(event_init.movement_y)
2628
, m_button(event_init.button)
@@ -56,27 +58,23 @@ static i16 determine_button(unsigned mouse_button)
5658
}
5759
}
5860

59-
JS::NonnullGCPtr<MouseEvent> MouseEvent::create(JS::Realm& realm, FlyString const& event_name, MouseEventInit const& event_init)
61+
JS::NonnullGCPtr<MouseEvent> MouseEvent::create(JS::Realm& realm, FlyString const& event_name, MouseEventInit const& event_init, double page_x, double page_y, double offset_x, double offset_y)
6062
{
61-
return realm.heap().allocate<MouseEvent>(realm, realm, event_name, event_init);
63+
return realm.heap().allocate<MouseEvent>(realm, realm, event_name, event_init, page_x, page_y, offset_x, offset_y);
6264
}
6365

64-
WebIDL::ExceptionOr<JS::NonnullGCPtr<MouseEvent>> MouseEvent::create_from_platform_event(JS::Realm& realm, FlyString const& event_name, CSSPixelPoint offset, CSSPixelPoint client_offset, CSSPixelPoint page_offset, Optional<CSSPixelPoint> movement, unsigned buttons, unsigned mouse_button)
66+
WebIDL::ExceptionOr<JS::NonnullGCPtr<MouseEvent>> MouseEvent::create_from_platform_event(JS::Realm& realm, FlyString const& event_name, CSSPixelPoint page, CSSPixelPoint client, CSSPixelPoint offset, Optional<CSSPixelPoint> movement, unsigned button, unsigned buttons)
6567
{
6668
MouseEventInit event_init {};
67-
event_init.offset_x = offset.x().to_double();
68-
event_init.offset_y = offset.y().to_double();
69-
event_init.client_x = client_offset.x().to_double();
70-
event_init.client_y = client_offset.y().to_double();
71-
event_init.page_x = page_offset.x().to_double();
72-
event_init.page_y = page_offset.y().to_double();
69+
event_init.client_x = client.x().to_double();
70+
event_init.client_y = client.y().to_double();
7371
if (movement.has_value()) {
7472
event_init.movement_x = movement.value().x().to_double();
7573
event_init.movement_y = movement.value().y().to_double();
7674
}
77-
event_init.button = determine_button(mouse_button);
75+
event_init.button = determine_button(button);
7876
event_init.buttons = buttons;
79-
return MouseEvent::create(realm, event_name, event_init);
77+
return MouseEvent::create(realm, event_name, event_init, page.x().to_double(), page.y().to_double(), offset.x().to_double(), offset.y().to_double());
8078
}
8179

8280
void MouseEvent::set_event_characteristics()

Userland/Libraries/LibWeb/UIEvents/MouseEvent.h

Lines changed: 19 additions & 21 deletions
Original file line numberDiff line numberDiff line change
@@ -14,15 +14,12 @@
1414
namespace Web::UIEvents {
1515

1616
struct MouseEventInit : public EventModifierInit {
17-
double offset_x = 0;
18-
double offset_y = 0;
17+
double screen_x = 0;
18+
double screen_y = 0;
1919
double client_x = 0;
2020
double client_y = 0;
21-
double page_x = 0;
22-
double page_y = 0;
2321
double movement_x = 0;
2422
double movement_y = 0;
25-
2623
i16 button = 0;
2724
u16 buttons = 0;
2825
};
@@ -31,27 +28,26 @@ class MouseEvent : public UIEvent {
3128
WEB_PLATFORM_OBJECT(MouseEvent, UIEvent);
3229

3330
public:
34-
[[nodiscard]] static JS::NonnullGCPtr<MouseEvent> create(JS::Realm&, FlyString const& event_name, MouseEventInit const& = {});
35-
static WebIDL::ExceptionOr<JS::NonnullGCPtr<MouseEvent>> create_from_platform_event(JS::Realm&, FlyString const& event_name, CSSPixelPoint offset, CSSPixelPoint client_offset, CSSPixelPoint page_offset, Optional<CSSPixelPoint> movement, unsigned buttons, unsigned mouse_button = 1);
31+
[[nodiscard]] static JS::NonnullGCPtr<MouseEvent> create(JS::Realm&, FlyString const& event_name, MouseEventInit const& = {}, double page_x = 0, double page_y = 0, double offset_x = 0, double offset_y = 0);
32+
static WebIDL::ExceptionOr<JS::NonnullGCPtr<MouseEvent>> create_from_platform_event(JS::Realm&, FlyString const& event_name, CSSPixelPoint page, CSSPixelPoint client, CSSPixelPoint offset, Optional<CSSPixelPoint> movement, unsigned button, unsigned buttons);
3633

3734
virtual ~MouseEvent() override;
3835

39-
double offset_x() const { return m_offset_x; }
40-
double offset_y() const { return m_offset_y; }
41-
42-
double client_x() const { return m_client_x; }
43-
double client_y() const { return m_client_y; }
44-
45-
// FIXME: Make these actually different from clientX and clientY.
46-
double screen_x() const { return m_client_x; }
47-
double screen_y() const { return m_client_y; }
36+
double screen_x() const { return m_screen_x; }
37+
double screen_y() const { return m_screen_y; }
4838

4939
double page_x() const { return m_page_x; }
5040
double page_y() const { return m_page_y; }
5141

42+
double client_x() const { return m_client_x; }
43+
double client_y() const { return m_client_y; }
44+
5245
double x() const { return client_x(); }
5346
double y() const { return client_y(); }
5447

48+
double offset_x() const { return m_offset_x; }
49+
double offset_y() const { return m_offset_y; }
50+
5551
double movement_x() const { return m_movement_x; }
5652
double movement_y() const { return m_movement_y; }
5753

@@ -61,19 +57,21 @@ class MouseEvent : public UIEvent {
6157
virtual u32 which() const override { return m_button + 1; }
6258

6359
protected:
64-
MouseEvent(JS::Realm&, FlyString const& event_name, MouseEventInit const& event_init);
60+
MouseEvent(JS::Realm&, FlyString const& event_name, MouseEventInit const& event_init, double page_x, double page_y, double offset_x, double offset_y);
6561

6662
virtual void initialize(JS::Realm&) override;
6763

6864
private:
6965
void set_event_characteristics();
7066

71-
double m_offset_x { 0 };
72-
double m_offset_y { 0 };
73-
double m_client_x { 0 };
74-
double m_client_y { 0 };
67+
double m_screen_x { 0 };
68+
double m_screen_y { 0 };
7569
double m_page_x { 0 };
7670
double m_page_y { 0 };
71+
double m_client_x { 0 };
72+
double m_client_y { 0 };
73+
double m_offset_x { 0 };
74+
double m_offset_y { 0 };
7775
double m_movement_x { 0 };
7876
double m_movement_y { 0 };
7977
i16 m_button { 0 };
Lines changed: 23 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -1,31 +1,42 @@
11
// https://w3c.github.io/uievents/#mouseevent
22
[Exposed=Window]
33
interface MouseEvent : UIEvent {
4+
// FIXME: constructor(DOMString type, optional MouseEventInit eventInitDict = {});
45

5-
readonly attribute double offsetX;
6-
readonly attribute double offsetY;
7-
readonly attribute double clientX;
8-
readonly attribute double clientY;
6+
// https://drafts.csswg.org/cssom-view/#extensions-to-the-mouseevent-interface
97
readonly attribute double screenX;
108
readonly attribute double screenY;
11-
readonly attribute double x;
12-
readonly attribute double y;
139
readonly attribute double pageX;
1410
readonly attribute double pageY;
11+
readonly attribute double clientX;
12+
readonly attribute double clientY;
13+
readonly attribute double x;
14+
readonly attribute double y;
15+
readonly attribute double offsetX;
16+
readonly attribute double offsetY;
17+
18+
// FIXME: readonly attribute boolean ctrlKey;
19+
// FIXME: readonly attribute boolean shiftKey;
20+
// FIXME: readonly attribute boolean altKey;
21+
// FIXME: readonly attribute boolean metaKey;
1522

1623
// https://w3c.github.io/pointerlock/#extensions-to-the-mouseevent-interface
1724
readonly attribute double movementX;
1825
readonly attribute double movementY;
1926

2027
readonly attribute short button;
2128
readonly attribute unsigned short buttons;
29+
30+
// FIXME: readonly attribute EventTarget? relatedTarget;
31+
32+
// FIXME: boolean getModifierState(DOMString keyArg);
2233
};
2334

35+
// https://w3c.github.io/uievents/#idl-mouseeventinit
2436
dictionary MouseEventInit : EventModifierInit {
25-
26-
// FIXME: offsetX and offsetY shouldn't be here.
27-
double offsetX = 0;
28-
double offsetY = 0;
37+
// https://drafts.csswg.org/cssom-view/#extensions-to-the-mouseevent-interface
38+
double screenX = 0;
39+
double screenY = 0;
2940
double clientX = 0;
3041
double clientY = 0;
3142

@@ -34,5 +45,6 @@ dictionary MouseEventInit : EventModifierInit {
3445
double movementY = 0;
3546

3647
short button = 0;
37-
48+
unsigned short buttons = 0;
49+
// FIXME: EventTarget? relatedTarget = null;
3850
};

Userland/Libraries/LibWeb/UIEvents/WheelEvent.cpp

Lines changed: 8 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -12,8 +12,8 @@
1212

1313
namespace Web::UIEvents {
1414

15-
WheelEvent::WheelEvent(JS::Realm& realm, FlyString const& event_name, WheelEventInit const& event_init)
16-
: MouseEvent(realm, event_name, event_init)
15+
WheelEvent::WheelEvent(JS::Realm& realm, FlyString const& event_name, WheelEventInit const& event_init, double page_x, double page_y, double offset_x, double offset_y)
16+
: MouseEvent(realm, event_name, event_init, page_x, page_y, offset_x, offset_y)
1717
, m_delta_x(event_init.delta_x)
1818
, m_delta_y(event_init.delta_y)
1919
, m_delta_mode(event_init.delta_mode)
@@ -29,24 +29,22 @@ void WheelEvent::initialize(JS::Realm& realm)
2929
set_prototype(&Bindings::ensure_web_prototype<Bindings::WheelEventPrototype>(realm, "WheelEvent"));
3030
}
3131

32-
JS::NonnullGCPtr<WheelEvent> WheelEvent::create(JS::Realm& realm, FlyString const& event_name, WheelEventInit const& event_init)
32+
JS::NonnullGCPtr<WheelEvent> WheelEvent::create(JS::Realm& realm, FlyString const& event_name, WheelEventInit const& event_init, double page_x, double page_y, double offset_x, double offset_y)
3333
{
34-
return realm.heap().allocate<WheelEvent>(realm, realm, event_name, event_init);
34+
return realm.heap().allocate<WheelEvent>(realm, realm, event_name, event_init, page_x, page_y, offset_x, offset_y);
3535
}
3636

37-
WebIDL::ExceptionOr<JS::NonnullGCPtr<WheelEvent>> WheelEvent::create_from_platform_event(JS::Realm& realm, FlyString const& event_name, CSSPixels offset_x, CSSPixels offset_y, CSSPixels client_x, CSSPixels client_y, double delta_x, double delta_y, unsigned buttons, unsigned button)
37+
WebIDL::ExceptionOr<JS::NonnullGCPtr<WheelEvent>> WheelEvent::create_from_platform_event(JS::Realm& realm, FlyString const& event_name, CSSPixelPoint page, CSSPixelPoint client, CSSPixelPoint offset, double delta_x, double delta_y, unsigned button, unsigned buttons)
3838
{
3939
WheelEventInit event_init {};
40-
event_init.offset_x = offset_x.to_double();
41-
event_init.offset_y = offset_y.to_double();
42-
event_init.client_x = client_x.to_double();
43-
event_init.client_y = client_y.to_double();
40+
event_init.client_x = client.x().to_double();
41+
event_init.client_y = client.y().to_double();
4442
event_init.button = button;
4543
event_init.buttons = buttons;
4644
event_init.delta_x = delta_x;
4745
event_init.delta_y = delta_y;
4846
event_init.delta_mode = WheelDeltaMode::DOM_DELTA_PIXEL;
49-
return WheelEvent::create(realm, event_name, event_init);
47+
return WheelEvent::create(realm, event_name, event_init, page.x().to_double(), page.y().to_double(), offset.x().to_double(), offset.y().to_double());
5048
}
5149

5250
void WheelEvent::set_event_characteristics()

Userland/Libraries/LibWeb/UIEvents/WheelEvent.h

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -29,8 +29,8 @@ class WheelEvent final : public MouseEvent {
2929
WEB_PLATFORM_OBJECT(WheelEvent, MouseEvent);
3030

3131
public:
32-
[[nodiscard]] static JS::NonnullGCPtr<WheelEvent> create(JS::Realm&, FlyString const& event_name, WheelEventInit const& event_init = {});
33-
static WebIDL::ExceptionOr<JS::NonnullGCPtr<WheelEvent>> create_from_platform_event(JS::Realm&, FlyString const& event_name, CSSPixels offset_x, CSSPixels offset_y, CSSPixels client_x, CSSPixels client_y, double delta_x, double delta_y, unsigned buttons, unsigned button);
32+
[[nodiscard]] static JS::NonnullGCPtr<WheelEvent> create(JS::Realm&, FlyString const& event_name, WheelEventInit const& event_init = {}, double page_x = 0, double page_y = 0, double offset_x = 0, double offset_y = 0);
33+
static WebIDL::ExceptionOr<JS::NonnullGCPtr<WheelEvent>> create_from_platform_event(JS::Realm&, FlyString const& event_name, CSSPixelPoint page, CSSPixelPoint client, CSSPixelPoint offset, double delta_x, double delta_y, unsigned button, unsigned buttons);
3434

3535
virtual ~WheelEvent() override;
3636

@@ -40,7 +40,7 @@ class WheelEvent final : public MouseEvent {
4040
unsigned long delta_mode() const { return to_underlying(m_delta_mode); }
4141

4242
private:
43-
WheelEvent(JS::Realm&, FlyString const& event_name, WheelEventInit const& event_init);
43+
WheelEvent(JS::Realm&, FlyString const& event_name, WheelEventInit const& event_init, double page_x, double page_y, double offset_x, double offset_y);
4444

4545
virtual void initialize(JS::Realm&) override;
4646

0 commit comments

Comments
 (0)