mirror of
https://github.com/RGBCube/serenity
synced 2025-05-23 14:35:07 +00:00
Ladybird/Qt: Migrate to LibWebView for search engines
This commit is contained in:
parent
e8d921820a
commit
f8f0c5459d
4 changed files with 34 additions and 37 deletions
|
@ -30,15 +30,13 @@ LocationEdit::LocationEdit(QWidget* parent)
|
||||||
connect(this, &QLineEdit::returnPressed, [&] {
|
connect(this, &QLineEdit::returnPressed, [&] {
|
||||||
clearFocus();
|
clearFocus();
|
||||||
|
|
||||||
Optional<String> search_engine_url;
|
Optional<StringView> search_engine_url;
|
||||||
if (Settings::the()->enable_search()) {
|
if (Settings::the()->enable_search())
|
||||||
auto search_engine = Settings::the()->search_engine();
|
search_engine_url = Settings::the()->search_engine().query_url;
|
||||||
search_engine_url = MUST(ak_string_from_qstring(search_engine.url));
|
|
||||||
}
|
|
||||||
|
|
||||||
auto query = MUST(ak_string_from_qstring(text()));
|
auto query = MUST(ak_string_from_qstring(text()));
|
||||||
|
|
||||||
if (auto url = WebView::sanitize_url(query, search_engine_url.map([](auto& value) { return value.bytes_as_string_view(); })); url.has_value())
|
if (auto url = WebView::sanitize_url(query, search_engine_url); url.has_value())
|
||||||
setText(qstring_from_ak_deprecated_string(url->serialize()));
|
setText(qstring_from_ak_deprecated_string(url->serialize()));
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -30,8 +30,20 @@ static QString rebase_default_url_on_serenity_resource_root(StringView default_u
|
||||||
}
|
}
|
||||||
|
|
||||||
Settings::Settings()
|
Settings::Settings()
|
||||||
|
: m_search_engine(WebView::default_search_engine())
|
||||||
{
|
{
|
||||||
m_qsettings = make<QSettings>("Serenity", "Ladybird", this);
|
m_qsettings = make<QSettings>("Serenity", "Ladybird", this);
|
||||||
|
|
||||||
|
auto default_search_engine = WebView::default_search_engine();
|
||||||
|
auto default_search_engine_name = qstring_from_ak_deprecated_string(default_search_engine.name);
|
||||||
|
|
||||||
|
auto search_engine_name = m_qsettings->value("search_engine_name", default_search_engine_name).toString();
|
||||||
|
auto search_engine = WebView::find_search_engine(MUST(ak_string_from_qstring(search_engine_name)));
|
||||||
|
|
||||||
|
if (search_engine.has_value())
|
||||||
|
m_search_engine = search_engine.release_value();
|
||||||
|
else
|
||||||
|
set_search_engine(move(default_search_engine));
|
||||||
}
|
}
|
||||||
|
|
||||||
Optional<QPoint> Settings::last_position()
|
Optional<QPoint> Settings::last_position()
|
||||||
|
@ -66,18 +78,10 @@ void Settings::set_is_maximized(bool is_maximized)
|
||||||
m_qsettings->setValue("is_maximized", is_maximized);
|
m_qsettings->setValue("is_maximized", is_maximized);
|
||||||
}
|
}
|
||||||
|
|
||||||
Settings::EngineProvider Settings::search_engine()
|
void Settings::set_search_engine(WebView::SearchEngine search_engine)
|
||||||
{
|
{
|
||||||
EngineProvider engine_provider;
|
m_qsettings->setValue("search_engine_name", qstring_from_ak_deprecated_string(search_engine.name));
|
||||||
engine_provider.name = m_qsettings->value("search_engine_name", "Google").toString();
|
m_search_engine = move(search_engine);
|
||||||
engine_provider.url = m_qsettings->value("search_engine", "https://www.google.com/search?q={}").toString();
|
|
||||||
return engine_provider;
|
|
||||||
}
|
|
||||||
|
|
||||||
void Settings::set_search_engine(EngineProvider const& engine_provider)
|
|
||||||
{
|
|
||||||
m_qsettings->setValue("search_engine_name", engine_provider.name);
|
|
||||||
m_qsettings->setValue("search_engine", engine_provider.url);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Settings::EngineProvider Settings::autocomplete_engine()
|
Settings::EngineProvider Settings::autocomplete_engine()
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
|
|
||||||
#include <AK/DeprecatedString.h>
|
#include <AK/DeprecatedString.h>
|
||||||
#include <AK/OwnPtr.h>
|
#include <AK/OwnPtr.h>
|
||||||
|
#include <LibWebView/SearchEngine.h>
|
||||||
#include <QPoint>
|
#include <QPoint>
|
||||||
#include <QSettings>
|
#include <QSettings>
|
||||||
#include <QSize>
|
#include <QSize>
|
||||||
|
@ -38,14 +39,14 @@ public:
|
||||||
QString new_tab_page();
|
QString new_tab_page();
|
||||||
void set_new_tab_page(QString const& page);
|
void set_new_tab_page(QString const& page);
|
||||||
|
|
||||||
|
WebView::SearchEngine search_engine() const { return m_search_engine; }
|
||||||
|
void set_search_engine(WebView::SearchEngine engine);
|
||||||
|
|
||||||
struct EngineProvider {
|
struct EngineProvider {
|
||||||
QString name;
|
QString name;
|
||||||
QString url;
|
QString url;
|
||||||
};
|
};
|
||||||
|
|
||||||
EngineProvider search_engine();
|
|
||||||
void set_search_engine(EngineProvider const& engine);
|
|
||||||
|
|
||||||
EngineProvider autocomplete_engine();
|
EngineProvider autocomplete_engine();
|
||||||
void set_autocomplete_engine(EngineProvider const& engine);
|
void set_autocomplete_engine(EngineProvider const& engine);
|
||||||
|
|
||||||
|
@ -60,6 +61,7 @@ protected:
|
||||||
|
|
||||||
private:
|
private:
|
||||||
OwnPtr<QSettings> m_qsettings;
|
OwnPtr<QSettings> m_qsettings;
|
||||||
|
WebView::SearchEngine m_search_engine;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
#include "Settings.h"
|
#include "Settings.h"
|
||||||
#include "StringUtils.h"
|
#include "StringUtils.h"
|
||||||
#include <AK/URL.h>
|
#include <AK/URL.h>
|
||||||
|
#include <LibWebView/SearchEngine.h>
|
||||||
#include <QLabel>
|
#include <QLabel>
|
||||||
#include <QMenu>
|
#include <QMenu>
|
||||||
|
|
||||||
|
@ -23,7 +24,7 @@ SettingsDialog::SettingsDialog(QMainWindow* window)
|
||||||
m_enable_search->setChecked(Settings::the()->enable_search());
|
m_enable_search->setChecked(Settings::the()->enable_search());
|
||||||
|
|
||||||
m_search_engine_dropdown = make<QToolButton>(this);
|
m_search_engine_dropdown = make<QToolButton>(this);
|
||||||
m_search_engine_dropdown->setText(Settings::the()->search_engine().name);
|
m_search_engine_dropdown->setText(qstring_from_ak_deprecated_string(Settings::the()->search_engine().name));
|
||||||
|
|
||||||
m_enable_autocomplete = make<QCheckBox>(this);
|
m_enable_autocomplete = make<QCheckBox>(this);
|
||||||
m_enable_autocomplete->setChecked(Settings::the()->enable_autocomplete());
|
m_enable_autocomplete->setChecked(Settings::the()->enable_autocomplete());
|
||||||
|
@ -64,18 +65,7 @@ SettingsDialog::SettingsDialog(QMainWindow* window)
|
||||||
|
|
||||||
void SettingsDialog::setup_search_engines()
|
void SettingsDialog::setup_search_engines()
|
||||||
{
|
{
|
||||||
// FIXME: These should be in a config file.
|
// FIXME: These should be centralized in LibWebView.
|
||||||
Vector<Settings::EngineProvider> search_engines = {
|
|
||||||
{ "Bing", "https://www.bing.com/search?q={}" },
|
|
||||||
{ "Brave", "https://search.brave.com/search?q={}" },
|
|
||||||
{ "DuckDuckGo", "https://duckduckgo.com/?q={}" },
|
|
||||||
{ "GitHub", "https://github.com/search?q={}" },
|
|
||||||
{ "Google", "https://google.com/search?q={}" },
|
|
||||||
{ "Mojeek", "https://www.mojeek.com/search?q={}" },
|
|
||||||
{ "Yahoo", "https://search.yahoo.com/search?p={}" },
|
|
||||||
{ "Yandex", "https://yandex.com/search/?text={}" },
|
|
||||||
};
|
|
||||||
|
|
||||||
Vector<Settings::EngineProvider> autocomplete_engines = {
|
Vector<Settings::EngineProvider> autocomplete_engines = {
|
||||||
{ "DuckDuckGo", "https://duckduckgo.com/ac/?q={}" },
|
{ "DuckDuckGo", "https://duckduckgo.com/ac/?q={}" },
|
||||||
{ "Google", "https://www.google.com/complete/search?client=chrome&q={}" },
|
{ "Google", "https://www.google.com/complete/search?client=chrome&q={}" },
|
||||||
|
@ -83,12 +73,15 @@ void SettingsDialog::setup_search_engines()
|
||||||
};
|
};
|
||||||
|
|
||||||
QMenu* search_engine_menu = new QMenu(this);
|
QMenu* search_engine_menu = new QMenu(this);
|
||||||
for (auto& search_engine : search_engines) {
|
for (auto const& search_engine : WebView::search_engines()) {
|
||||||
QAction* action = new QAction(search_engine.name, this);
|
auto search_engine_name = qstring_from_ak_deprecated_string(search_engine.name);
|
||||||
connect(action, &QAction::triggered, this, [&, search_engine] {
|
QAction* action = new QAction(search_engine_name, this);
|
||||||
|
|
||||||
|
connect(action, &QAction::triggered, this, [&, search_engine_name = std::move(search_engine_name)]() {
|
||||||
Settings::the()->set_search_engine(search_engine);
|
Settings::the()->set_search_engine(search_engine);
|
||||||
m_search_engine_dropdown->setText(search_engine.name);
|
m_search_engine_dropdown->setText(search_engine_name);
|
||||||
});
|
});
|
||||||
|
|
||||||
search_engine_menu->addAction(action);
|
search_engine_menu->addAction(action);
|
||||||
}
|
}
|
||||||
m_search_engine_dropdown->setMenu(search_engine_menu);
|
m_search_engine_dropdown->setMenu(search_engine_menu);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue