mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-24 18:32:28 -05:00
eb21aa65d1
This changes client methods so that they return the IPC response's return value directly - instead of the response struct - for IPC methods which only have a single return value.
202 lines
5.5 KiB
C++
202 lines
5.5 KiB
C++
/*
|
|
* Copyright (c) 2020-2021, Andreas Kling <kling@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include "PageHost.h"
|
|
#include "ClientConnection.h"
|
|
#include <LibGfx/Painter.h>
|
|
#include <LibGfx/SystemTheme.h>
|
|
#include <LibWeb/Cookie/ParsedCookie.h>
|
|
#include <LibWeb/Layout/InitialContainingBlockBox.h>
|
|
#include <LibWeb/Page/Frame.h>
|
|
#include <WebContent/WebContentClientEndpoint.h>
|
|
|
|
namespace WebContent {
|
|
|
|
PageHost::PageHost(ClientConnection& client)
|
|
: m_client(client)
|
|
, m_page(make<Web::Page>(*this))
|
|
{
|
|
setup_palette();
|
|
}
|
|
|
|
PageHost::~PageHost()
|
|
{
|
|
}
|
|
|
|
void PageHost::setup_palette()
|
|
{
|
|
// FIXME: Get the proper palette from our peer somehow
|
|
auto buffer = Core::AnonymousBuffer::create_with_size(sizeof(Gfx::SystemTheme));
|
|
auto* theme = buffer.data<Gfx::SystemTheme>();
|
|
theme->color[(int)Gfx::ColorRole::Window] = Color::Magenta;
|
|
theme->color[(int)Gfx::ColorRole::WindowText] = Color::Cyan;
|
|
m_palette_impl = Gfx::PaletteImpl::create_with_anonymous_buffer(buffer);
|
|
}
|
|
|
|
Gfx::Palette PageHost::palette() const
|
|
{
|
|
return Gfx::Palette(*m_palette_impl);
|
|
}
|
|
|
|
void PageHost::set_palette_impl(const Gfx::PaletteImpl& impl)
|
|
{
|
|
m_palette_impl = impl;
|
|
}
|
|
|
|
Web::Layout::InitialContainingBlockBox* PageHost::layout_root()
|
|
{
|
|
auto* document = page().main_frame().document();
|
|
if (!document)
|
|
return nullptr;
|
|
return document->layout_node();
|
|
}
|
|
|
|
void PageHost::paint(const Gfx::IntRect& content_rect, Gfx::Bitmap& target)
|
|
{
|
|
Gfx::Painter painter(target);
|
|
Gfx::IntRect bitmap_rect { {}, content_rect.size() };
|
|
|
|
auto* layout_root = this->layout_root();
|
|
if (!layout_root) {
|
|
painter.fill_rect(bitmap_rect, Color::White);
|
|
return;
|
|
}
|
|
|
|
Web::PaintContext context(painter, palette(), content_rect.top_left());
|
|
context.set_should_show_line_box_borders(m_should_show_line_box_borders);
|
|
context.set_viewport_rect(content_rect);
|
|
layout_root->paint_all_phases(context);
|
|
}
|
|
|
|
void PageHost::set_viewport_rect(const Gfx::IntRect& rect)
|
|
{
|
|
page().main_frame().set_viewport_rect(rect);
|
|
}
|
|
|
|
void PageHost::page_did_invalidate(const Gfx::IntRect& content_rect)
|
|
{
|
|
m_client.async_did_invalidate_content_rect(content_rect);
|
|
}
|
|
|
|
void PageHost::page_did_change_selection()
|
|
{
|
|
m_client.async_did_change_selection();
|
|
}
|
|
|
|
void PageHost::page_did_request_cursor_change(Gfx::StandardCursor cursor)
|
|
{
|
|
m_client.async_did_request_cursor_change((u32)cursor);
|
|
}
|
|
|
|
void PageHost::page_did_layout()
|
|
{
|
|
auto* layout_root = this->layout_root();
|
|
VERIFY(layout_root);
|
|
auto content_size = enclosing_int_rect(layout_root->absolute_rect()).size();
|
|
m_client.async_did_layout(content_size);
|
|
}
|
|
|
|
void PageHost::page_did_change_title(const String& title)
|
|
{
|
|
m_client.async_did_change_title(title);
|
|
}
|
|
|
|
void PageHost::page_did_request_scroll(int wheel_delta)
|
|
{
|
|
m_client.async_did_request_scroll(wheel_delta);
|
|
}
|
|
|
|
void PageHost::page_did_request_scroll_into_view(const Gfx::IntRect& rect)
|
|
{
|
|
m_client.async_did_request_scroll_into_view(rect);
|
|
}
|
|
|
|
void PageHost::page_did_enter_tooltip_area(const Gfx::IntPoint& content_position, const String& title)
|
|
{
|
|
m_client.async_did_enter_tooltip_area(content_position, title);
|
|
}
|
|
|
|
void PageHost::page_did_leave_tooltip_area()
|
|
{
|
|
m_client.async_did_leave_tooltip_area();
|
|
}
|
|
|
|
void PageHost::page_did_hover_link(const URL& url)
|
|
{
|
|
m_client.async_did_hover_link(url);
|
|
}
|
|
|
|
void PageHost::page_did_unhover_link()
|
|
{
|
|
m_client.async_did_unhover_link();
|
|
}
|
|
|
|
void PageHost::page_did_click_link(const URL& url, const String& target, unsigned modifiers)
|
|
{
|
|
m_client.async_did_click_link(url, target, modifiers);
|
|
}
|
|
|
|
void PageHost::page_did_middle_click_link(const URL& url, [[maybe_unused]] const String& target, [[maybe_unused]] unsigned modifiers)
|
|
{
|
|
m_client.async_did_middle_click_link(url, target, modifiers);
|
|
}
|
|
|
|
void PageHost::page_did_start_loading(const URL& url)
|
|
{
|
|
m_client.async_did_start_loading(url);
|
|
}
|
|
|
|
void PageHost::page_did_finish_loading(const URL& url)
|
|
{
|
|
m_client.async_did_finish_loading(url);
|
|
}
|
|
|
|
void PageHost::page_did_request_context_menu(const Gfx::IntPoint& content_position)
|
|
{
|
|
m_client.async_did_request_context_menu(content_position);
|
|
}
|
|
|
|
void PageHost::page_did_request_link_context_menu(const Gfx::IntPoint& content_position, const URL& url, const String& target, unsigned modifiers)
|
|
{
|
|
m_client.async_did_request_link_context_menu(content_position, url, target, modifiers);
|
|
}
|
|
|
|
void PageHost::page_did_request_alert(const String& message)
|
|
{
|
|
m_client.did_request_alert(message);
|
|
}
|
|
|
|
bool PageHost::page_did_request_confirm(const String& message)
|
|
{
|
|
return m_client.did_request_confirm(message);
|
|
}
|
|
|
|
String PageHost::page_did_request_prompt(const String& message, const String& default_)
|
|
{
|
|
return m_client.did_request_prompt(message, default_);
|
|
}
|
|
|
|
void PageHost::page_did_change_favicon(const Gfx::Bitmap& favicon)
|
|
{
|
|
m_client.async_did_change_favicon(favicon.to_shareable_bitmap());
|
|
}
|
|
|
|
void PageHost::page_did_request_image_context_menu(const Gfx::IntPoint& content_position, const URL& url, const String& target, unsigned modifiers, const Gfx::Bitmap* bitmap)
|
|
{
|
|
m_client.async_did_request_image_context_menu(content_position, url, target, modifiers, bitmap->to_shareable_bitmap());
|
|
}
|
|
|
|
String PageHost::page_did_request_cookie(const URL& url, Web::Cookie::Source source)
|
|
{
|
|
return m_client.did_request_cookie(url, static_cast<u8>(source));
|
|
}
|
|
|
|
void PageHost::page_did_set_cookie(const URL& url, const Web::Cookie::ParsedCookie& cookie, Web::Cookie::Source source)
|
|
{
|
|
m_client.async_did_set_cookie(url, cookie, static_cast<u8>(source));
|
|
}
|
|
|
|
}
|