Skip to content
This repository has been archived by the owner on May 10, 2024. It is now read-only.

Fix #3177: Update pre-populated search engine list #3189

Merged
merged 2 commits into from
Jan 13, 2021
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
18 changes: 18 additions & 0 deletions Client/Assets/SearchPlugins/ecosia.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
<!-- This Source Code Form is subject to the terms of the Mozilla Public
- License, v. 2.0. If a copy of the MPL was not distributed with this
- file, You can obtain one at http://mozilla.org/MPL/2.0/. -->

<SearchPlugin xmlns="http://www.mozilla.org/2006/browser/search/">
<ShortName>Ecosia</ShortName>
<InputEncoding>UTF-8</InputEncoding>
<Image width="16" height="16"></Image>
<Url type="text/html" method="get" template="https://www.ecosia.org/search" >
<Param name="q" value="{searchTerms}"/>
<Param name="tt" value="d188c5da"/>
</Url>
<Url type="application/x-suggestions+json" template="https://ac.ecosia.org/autocomplete" >
<Param name="q" value="{searchTerms}"/>
<Param name="type" value="list"/>
</Url>
<SearchForm>https://www.ecosia.org</SearchForm>
</SearchPlugin>
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ class OnboardingSearchEnginesViewController: OnboardingViewController {
}

private lazy var availableEngines: [OpenSearchEngine] = {
SearchEngines.getUnorderedBundledEnginesFor()
SearchEngines.getUnorderedBundledEngines(isOnboarding: true)
}()

private var contentView: View {
Expand Down
35 changes: 27 additions & 8 deletions Client/Frontend/Browser/Search/InitialSearchEngines.swift
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,16 @@ import Foundation
class InitialSearchEngines {
/// Type of search engine available to the user.
enum SearchEngineID: String {
case google, bing, duckduckgo, yandex, qwant, startpage, yahoo
case google, bing, duckduckgo, yandex, qwant, startpage, yahoo, ecosia

var excludedFromOnboarding: Bool {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This property is temporary right until we remove the yahoo engine totally ?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think we can keep it, if we add a lot of predefined search engines in the future we can choose which of them to show during onboarding, to avoid having a long list of search engines

switch self {
case .google, .bing, .duckduckgo, .yandex, .qwant, .startpage, .ecosia:
return false
case .yahoo:
return true
}
}
}

struct SearchEngine: Equatable, CustomStringConvertible {
Expand Down Expand Up @@ -39,9 +48,15 @@ class InitialSearchEngines {
/// List of available engines for given locale. This list is sorted by with priority and default engines at the top.
var engines: [SearchEngine]

/// Lists of engines available during onboarding.
var onboardingEngines: [SearchEngine] {
engines.filter { !$0.id.excludedFromOnboarding }
}

static let ddgDefaultRegions = ["DE", "AU", "NZ", "IE"]
static let qwantDefaultRegions = ["FR"]
static let yandexDefaultRegions = ["AM", "AZ", "BY", "KG", "KZ", "MD", "RU", "TJ", "TM", "TZ"]
static let ecosiaDefaultRegions = ["US", "GB", "FR", "DE", "NL", "BE", "CH", "SE"]
static let yahooEligibleRegions =
["GB", "US", "AR", "AT", "AU", "BR", "CA", "CH", "CL", "CO", "DE", "DK", "ES", "FI", "FR", "HK",
"ID", "IE", "IN", "IT", "MX", "MY", "NL", "NO", "NZ", "PE", "PH", "SE", "SG", "TH", "TW", "VE", "VN"]
Expand Down Expand Up @@ -119,16 +134,20 @@ class InitialSearchEngines {
if Self.yandexDefaultRegions.contains(region) {
defaultSearchEngine = .yandex
}
}

private func priorityOverrides() {
guard let region = locale.regionCode else { return }
if Self.ecosiaDefaultRegions.contains(region) {
replaceOrInsert(engineId: .ecosia, customId: nil)
}

if Self.yahooEligibleRegions.contains(region) {
priorityEngine = .yahoo
replaceOrInsert(engineId: .yahoo, customId: nil)
}
}

private func priorityOverrides() {
// No priority engines are live at the moment.
soner-yuksel marked this conversation as resolved.
Show resolved Hide resolved
}

// MARK: - Helpers

private func sortEngines() {
Expand All @@ -137,8 +156,8 @@ class InitialSearchEngines {
.sorted { e, _ in e.id == priorityEngine }
}

private func replaceOrInsert(engineId: SearchEngineID, customId: String) {
guard let engineIndex = engines.firstIndex(of: .init(id: engineId)) else {
private func replaceOrInsert(engineId: SearchEngineID, customId: String?) {
guard let engineIndex = engines.firstIndex(where: { $0.id == engineId }) else {
engines.append(.init(id: engineId, customId: customId))
return
}
Expand Down
8 changes: 5 additions & 3 deletions Client/Frontend/Browser/Search/SearchEngines.swift
Original file line number Diff line number Diff line change
Expand Up @@ -250,7 +250,8 @@ class SearchEngines {

/// Get all bundled (not custom) search engines, with the default search engine first,
/// but the others in no particular order.
class func getUnorderedBundledEnginesFor(selected: [String] = []) -> [OpenSearchEngine] {
class func getUnorderedBundledEngines(for selectedEngines: [String] = [],
isOnboarding: Bool) -> [OpenSearchEngine] {
let parser = OpenSearchParser(pluginMode: true)

guard let pluginDirectory = Bundle.main.resourceURL?.appendingPathComponent("SearchPlugins") else {
Expand All @@ -259,7 +260,8 @@ class SearchEngines {
}

let se = InitialSearchEngines()
let engineNames = se.engines.map { $0.customId ?? $0.id.rawValue }
let engines = isOnboarding ? se.onboardingEngines : se.engines
let engineNames = engines.map { $0.customId ?? $0.id.rawValue }
assert(engineNames.count > 0, "No search engines")

return engineNames.map({ (name: $0, path: pluginDirectory.appendingPathComponent("\($0).xml").path) })
Expand All @@ -271,7 +273,7 @@ class SearchEngines {
fileprivate func getOrderedEngines() -> [OpenSearchEngine] {
let selectedSearchEngines = [Preferences.Search.defaultEngineName, Preferences.Search.defaultPrivateEngineName].compactMap { $0.value }
let unorderedEngines = customEngines
+ SearchEngines.getUnorderedBundledEnginesFor(selected: selectedSearchEngines)
+ SearchEngines.getUnorderedBundledEngines(for: selectedSearchEngines, isOnboarding: false)

// might not work to change the default.
guard let orderedEngineNames = Preferences.Search.orderedEngines.value else {
Expand Down
Loading