mirror of
https://github.com/lightpanda-io/browser.git
synced 2026-03-25 01:43:04 -04:00
Our BrowsingContext currently supports 1 target. So we have a per-BC target_id. Previously, our target had 1 "frame" - our page. So we often treated the targetId as the frameId. But to work with frames, we need page-specific frameIds and loaderIds. This tries to clean up our ids (a little). frameIds are now ids derived from a new incrementing page.id. This page.id has to be passed around (via http Requests and through notifications) in order to properly generate messages with a frameId.
119 lines
3.8 KiB
Zig
119 lines
3.8 KiB
Zig
// Copyright (C) 2023-2024 Lightpanda (Selecy SAS)
|
|
//
|
|
// Francis Bouvier <francis@lightpanda.io>
|
|
// Pierre Tachoire <pierre@lightpanda.io>
|
|
//
|
|
// This program is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU Affero General Public License as
|
|
// published by the Free Software Foundation, either version 3 of the
|
|
// License, or (at your option) any later version.
|
|
//
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU Affero General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU Affero General Public License
|
|
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
const std = @import("std");
|
|
|
|
pub fn processMessage(cmd: anytype) !void {
|
|
const action = std.meta.stringToEnum(enum {
|
|
dispatchKeyEvent,
|
|
dispatchMouseEvent,
|
|
insertText,
|
|
}, cmd.input.action) orelse return error.UnknownMethod;
|
|
|
|
switch (action) {
|
|
.dispatchKeyEvent => return dispatchKeyEvent(cmd),
|
|
.dispatchMouseEvent => return dispatchMouseEvent(cmd),
|
|
.insertText => return insertText(cmd),
|
|
}
|
|
}
|
|
|
|
// https://chromedevtools.github.io/devtools-protocol/tot/Input/#method-dispatchKeyEvent
|
|
fn dispatchKeyEvent(cmd: anytype) !void {
|
|
const params = (try cmd.params(struct {
|
|
type: Type,
|
|
key: []const u8 = "",
|
|
code: ?[]const u8 = null,
|
|
modifiers: u4 = 0,
|
|
// Many optional parameters are not implemented yet, see documentation url.
|
|
|
|
const Type = enum {
|
|
keyDown,
|
|
keyUp,
|
|
rawKeyDown,
|
|
char,
|
|
};
|
|
})) orelse return error.InvalidParams;
|
|
|
|
try cmd.sendResult(null, .{});
|
|
|
|
// quickly ignore types we know we don't handle
|
|
switch (params.type) {
|
|
.keyUp, .rawKeyDown, .char => return,
|
|
.keyDown => {},
|
|
}
|
|
|
|
const bc = cmd.browser_context orelse return;
|
|
const page = bc.session.currentPage() orelse return;
|
|
|
|
const KeyboardEvent = @import("../../browser/webapi/event/KeyboardEvent.zig");
|
|
const keyboard_event = try KeyboardEvent.initTrusted(comptime .wrap("keydown"), .{
|
|
.key = params.key,
|
|
.code = params.code,
|
|
.altKey = params.modifiers & 1 == 1,
|
|
.ctrlKey = params.modifiers & 2 == 2,
|
|
.metaKey = params.modifiers & 4 == 4,
|
|
.shiftKey = params.modifiers & 8 == 8,
|
|
}, page);
|
|
try page.triggerKeyboard(keyboard_event);
|
|
// result already sent
|
|
}
|
|
|
|
// https://chromedevtools.github.io/devtools-protocol/tot/Input/#method-dispatchMouseEvent
|
|
fn dispatchMouseEvent(cmd: anytype) !void {
|
|
const params = (try cmd.params(struct {
|
|
x: f64,
|
|
y: f64,
|
|
type: Type,
|
|
// Many optional parameters are not implemented yet, see documentation url.
|
|
|
|
const Type = enum {
|
|
mousePressed,
|
|
mouseReleased,
|
|
mouseMoved,
|
|
mouseWheel,
|
|
};
|
|
})) orelse return error.InvalidParams;
|
|
|
|
try cmd.sendResult(null, .{});
|
|
|
|
// quickly ignore types we know we don't handle
|
|
switch (params.type) {
|
|
.mouseMoved, .mouseWheel, .mouseReleased => return,
|
|
else => {},
|
|
}
|
|
|
|
const bc = cmd.browser_context orelse return;
|
|
const page = bc.session.currentPage() orelse return;
|
|
try page.triggerMouseClick(params.x, params.y);
|
|
// result already sent
|
|
}
|
|
|
|
// https://chromedevtools.github.io/devtools-protocol/tot/Input/#method-insertText
|
|
fn insertText(cmd: anytype) !void {
|
|
const params = (try cmd.params(struct {
|
|
text: []const u8, // The text to insert
|
|
})) orelse return error.InvalidParams;
|
|
|
|
const bc = cmd.browser_context orelse return;
|
|
const page = bc.session.currentPage() orelse return;
|
|
|
|
try page.insertText(params.text);
|
|
|
|
try cmd.sendResult(null, .{});
|
|
}
|