Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
7 changes: 4 additions & 3 deletions src/pages/settings.html
Original file line number Diff line number Diff line change
Expand Up @@ -121,17 +121,18 @@ <h1 class="section-title">Search Engine</h1>
<div class="setting-label">Default search engine</div>
<div class="setting-control">
<div class="custom-select" id="search-engine-select">
<div class="select-display" data-value="duckduckgo">DuckDuckGo</div>
<div class="select-display" data-value="duckduckgo_noai">DuckDuckGo (No AI)</div>
<div class="select-dropdown">
<div class="select-option" data-value="duckduckgo">DuckDuckGo</div>
<div class="select-option" data-value="duckduckgo_noai">DuckDuckGo (No AI)</div>
<div class="select-option" data-value="duckduckgo">DuckDuckGo (AI)</div>
<div class="select-option" data-value="brave">Brave Search</div>
<div class="select-option" data-value="ecosia">Ecosia</div>
<div class="select-option" data-value="kagi">Kagi</div>
<div class="select-option" data-value="startpage">Startpage</div>
<div class="select-option" data-value="custom">Custom</div>
</div>
</div>
<input type="hidden" id="search-engine" value="duckduckgo">
<input type="hidden" id="search-engine" value="duckduckgo_noai">
</div>
</div>

Expand Down
2 changes: 1 addition & 1 deletion src/pages/static/js/settings.js
Original file line number Diff line number Diff line change
Expand Up @@ -564,7 +564,7 @@ function loadDefaultSettings() {
const keepTabsExpanded = document.getElementById('keep-tabs-expanded');
const wallpaperSelector = document.getElementById('wallpaper-selector');

if (searchEngine) searchEngine.value = 'duckduckgo';
if (searchEngine) searchEngine.value = 'duckduckgo_noai';
if (themeToggle) themeToggle.value = 'dark';
if (showClock) showClock.checked = true;
if (verticalTabs) verticalTabs.checked = false;
Expand Down
1 change: 1 addition & 0 deletions src/search-engine.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
export const BUILTIN_SEARCH_ENGINES = {
duckduckgo_noai: "https://noai.duckduckgo.com/?ia=web&q=%s",
duckduckgo: "https://duckduckgo.com/?q=%s",
brave: "https://search.brave.com/search?q=%s",
ecosia: "https://www.ecosia.org/search?q=%s",
Expand Down
7 changes: 4 additions & 3 deletions src/settings-manager.js
Original file line number Diff line number Diff line change
Expand Up @@ -454,7 +454,7 @@ class SettingsManager {

validateSetting(key, value) {
const validators = {
searchEngine: (v) => ['duckduckgo', 'brave', 'ecosia', 'kagi', 'startpage', "custom"].includes(v),
searchEngine: (v) => ['duckduckgo_noai', 'duckduckgo', 'brave', 'ecosia', 'kagi', 'startpage', "custom"].includes(v),
customSearchTemplate: (v) => {
if (typeof v !== "string" || v.length >= 2048) return false;
try {
Expand Down Expand Up @@ -598,14 +598,15 @@ class SettingsManager {

getSearchEngineName() {
const engineNames = {
'duckduckgo': 'DuckDuckGo',
'duckduckgo_noai': 'DuckDuckGo (No AI)',
'duckduckgo': 'DuckDuckGo (AI)',
'brave': 'Brave Search',
'ecosia': 'Ecosia',
'kagi': 'Kagi',
'startpage': 'Startpage',
'custom' : 'Custom'
};
return engineNames[this.settings.searchEngine] || 'DuckDuckGo';
return engineNames[this.settings.searchEngine] || 'DuckDuckGo (No AI)';
}

// Get wallpaper path for current setting
Expand Down
6 changes: 3 additions & 3 deletions src/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -31,8 +31,8 @@ function makeHttps(query) {
return `https://${query}`;
}

function makeSearch(query, engine = 'duckduckgo') {
const template = BUILTIN_SEARCH_ENGINES[engine] || BUILTIN_SEARCH_ENGINES.duckduckgo;
function makeSearch(query, engine = 'duckduckgo_noai') {
const template = BUILTIN_SEARCH_ENGINES[engine] || BUILTIN_SEARCH_ENGINES.duckduckgo_noai;
return template.replace("%s", encodeURIComponent(query));
}

Expand All @@ -53,7 +53,7 @@ function buildSearchUrl(template, term) {
url = new URL(template);
} catch {
// Fallback if invalid URL
return makeSearch(term, 'duckduckgo');
return makeSearch(term, 'duckduckgo_noai');
}

// (a) Fill first empty param, e.g. ?q=
Expand Down