mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-12-26 20:55:35 +03:00
Ladybird+LibWeb: Add initial about:version internal page
This commit is contained in:
parent
05c0640474
commit
cde14901bc
Notes:
sideshowbarker
2024-07-16 17:05:37 +09:00
Author: https://github.com/bplaat Commit: https://github.com/SerenityOS/serenity/commit/cde14901bc Pull-request: https://github.com/SerenityOS/serenity/pull/22708 Reviewed-by: https://github.com/ADKaster Reviewed-by: https://github.com/skyrising Reviewed-by: https://github.com/trflynn89
@ -9,6 +9,7 @@
|
||||
<ul>
|
||||
<li><a href="about:about">about:about</a></li>
|
||||
<li><a href="about:newtab">about:newtab</a></li>
|
||||
<li><a href="about:version">about:version</a></li>
|
||||
</ul>
|
||||
</body>
|
||||
</html>
|
||||
|
53
Base/res/ladybird/templates/version.html
Normal file
53
Base/res/ladybird/templates/version.html
Normal file
@ -0,0 +1,53 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title>About @browser_name@</title>
|
||||
<style>
|
||||
img {
|
||||
float: left;
|
||||
image-rendering: pixelated;
|
||||
margin-right: 10px;
|
||||
}
|
||||
th {
|
||||
text-align: right;
|
||||
}
|
||||
td {
|
||||
font-family: monospace;
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<header>
|
||||
<img src="resource://icons/32x32/app-browser.png">
|
||||
<h1>About @browser_name@</h1>
|
||||
</header>
|
||||
<table>
|
||||
<tr>
|
||||
<th>Version:</th>
|
||||
<td>@browser_version@ <!-- FIXME: Add build commit hash --></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th>Arch:</th>
|
||||
<td>@arch_name@</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th>Operating System:</th>
|
||||
<td>@os_name@</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th>User Agent:</th>
|
||||
<td>@user_agent@</td>
|
||||
</tr>
|
||||
<!-- FIXME: Add these fields
|
||||
<tr>
|
||||
<th>Command Line:</th>
|
||||
<td></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th>Executable Path:</th>
|
||||
<td></td>
|
||||
</tr> -->
|
||||
</table>
|
||||
</body>
|
||||
</html>
|
@ -148,6 +148,18 @@
|
||||
|
||||
#pragma mark - Private methods
|
||||
|
||||
- (void)openAboutVersionPage:(id)sender
|
||||
{
|
||||
auto* current_tab = [NSApp keyWindow];
|
||||
if (![current_tab isKindOfClass:[Tab class]]) {
|
||||
return;
|
||||
}
|
||||
|
||||
[self createNewTab:URL("about:version"sv)
|
||||
fromTab:(Tab*)current_tab
|
||||
activateTab:Web::HTML::ActivateTab::Yes];
|
||||
}
|
||||
|
||||
- (nonnull TabController*)createNewTab:(Web::HTML::ActivateTab)activate_tab
|
||||
fromTab:(nullable Tab*)tab
|
||||
{
|
||||
@ -242,7 +254,7 @@
|
||||
auto* submenu = [[NSMenu alloc] initWithTitle:process_name];
|
||||
|
||||
[submenu addItem:[[NSMenuItem alloc] initWithTitle:[NSString stringWithFormat:@"About %@", process_name]
|
||||
action:@selector(orderFrontStandardAboutPanel:)
|
||||
action:@selector(openAboutVersionPage:)
|
||||
keyEquivalent:@""]];
|
||||
[submenu addItem:[NSMenuItem separatorItem]];
|
||||
|
||||
|
@ -74,6 +74,11 @@ BrowserWindow::BrowserWindow(Vector<URL> const& initial_urls, WebView::CookieJar
|
||||
|
||||
auto* menu = menuBar()->addMenu("&File");
|
||||
|
||||
auto* about_action = new QAction("&About Ladybird", this);
|
||||
menu->addAction(about_action);
|
||||
|
||||
menu->addSeparator();
|
||||
|
||||
auto* new_tab_action = new QAction("New &Tab", this);
|
||||
new_tab_action->setIcon(load_icon_from_uri("resource://icons/16x16/new-tab.png"sv));
|
||||
new_tab_action->setShortcuts(QKeySequence::keyBindings(QKeySequence::StandardKey::AddTab));
|
||||
@ -375,6 +380,9 @@ BrowserWindow::BrowserWindow(Vector<URL> const& initial_urls, WebView::CookieJar
|
||||
debug_request("same-origin-policy", state ? "on" : "off");
|
||||
});
|
||||
|
||||
QObject::connect(about_action, &QAction::triggered, this, [this] {
|
||||
new_tab("about:version", Web::HTML::ActivateTab::Yes);
|
||||
});
|
||||
QObject::connect(new_tab_action, &QAction::triggered, this, [this] {
|
||||
new_tab(Settings::the()->new_tab_page(), Web::HTML::ActivateTab::Yes);
|
||||
});
|
||||
|
@ -12,6 +12,7 @@
|
||||
#include <LibCore/Resource.h>
|
||||
#include <LibCore/System.h>
|
||||
#include <LibWeb/Loader/GeneratedPagesLoader.h>
|
||||
#include <LibWeb/Loader/ResourceLoader.h>
|
||||
|
||||
namespace Web {
|
||||
|
||||
@ -68,4 +69,20 @@ ErrorOr<String> load_file_directory_page(AK::URL const& url)
|
||||
return TRY(String::from_utf8(generator.as_string_view()));
|
||||
}
|
||||
|
||||
ErrorOr<String> load_about_version_page()
|
||||
{
|
||||
// Generate HTML about version page from template file
|
||||
// FIXME: Use an actual templating engine (our own one when it's built, preferably with a way to check these usages at compile time)
|
||||
auto template_file = TRY(Core::Resource::load_from_uri("resource://ladybird/templates/version.html"sv));
|
||||
StringBuilder builder;
|
||||
SourceGenerator generator { builder };
|
||||
generator.set("browser_name", BROWSER_NAME);
|
||||
generator.set("browser_version", BROWSER_VERSION);
|
||||
generator.set("arch_name", CPU_STRING);
|
||||
generator.set("os_name", OS_STRING);
|
||||
generator.set("user_agent", default_user_agent);
|
||||
generator.append(template_file->data());
|
||||
return TRY(String::from_utf8(generator.as_string_view()));
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -15,4 +15,6 @@ ErrorOr<String> load_error_page(AK::URL const&);
|
||||
|
||||
ErrorOr<String> load_file_directory_page(AK::URL const&);
|
||||
|
||||
ErrorOr<String> load_about_version_page();
|
||||
|
||||
}
|
||||
|
@ -230,6 +230,12 @@ void ResourceLoader::load(LoadRequest& request, SuccessCallback success_callback
|
||||
HashMap<ByteString, ByteString, CaseInsensitiveStringTraits> response_headers;
|
||||
response_headers.set("Content-Type", "text/html; charset=UTF-8");
|
||||
|
||||
// About version page
|
||||
if (url.path_segment_at_index(0) == "version") {
|
||||
success_callback(MUST(load_about_version_page()).bytes(), response_headers, {});
|
||||
return;
|
||||
}
|
||||
|
||||
// Other about static HTML pages
|
||||
auto resource = Core::Resource::load_from_uri(MUST(String::formatted("resource://ladybird/{}.html", url.path_segment_at_index(0))));
|
||||
if (!resource.is_error()) {
|
||||
|
Loading…
Reference in New Issue
Block a user