0
0
mirror of https://github.com/neon-mmd/websurfx.git synced 2024-11-21 21:48:21 -05:00

Merge branch 'rolling' into 482

This commit is contained in:
Jorge Botto 2024-11-02 11:50:21 +00:00 committed by GitHub
commit f879456ff6
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
10 changed files with 75 additions and 149 deletions

97
Cargo.lock generated
View File

@ -14,7 +14,7 @@ dependencies = [
"futures-sink", "futures-sink",
"memchr", "memchr",
"pin-project-lite", "pin-project-lite",
"tokio 1.40.0", "tokio 1.41.0",
"tokio-util", "tokio-util",
"tracing", "tracing",
] ]
@ -59,9 +59,9 @@ dependencies = [
[[package]] [[package]]
name = "actix-governor" name = "actix-governor"
version = "0.6.0" version = "0.7.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "0954b0f27aabd8f56bb03f2a77b412ddf3f8c034a3c27b2086c1fc75415760df" checksum = "072a3d7907b945b0956f9721e01c117ad5765ce5be2fd9bb1e44a117c669de22"
dependencies = [ dependencies = [
"actix-http", "actix-http",
"actix-web", "actix-web",
@ -100,7 +100,7 @@ dependencies = [
"rand 0.8.5", "rand 0.8.5",
"sha1", "sha1",
"smallvec 1.13.2", "smallvec 1.13.2",
"tokio 1.40.0", "tokio 1.41.0",
"tokio-util", "tokio-util",
"tracing", "tracing",
] ]
@ -136,7 +136,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "24eda4e2a6e042aa4e55ac438a2ae052d3b5da0ecf83d7411e1a368946925208" checksum = "24eda4e2a6e042aa4e55ac438a2ae052d3b5da0ecf83d7411e1a368946925208"
dependencies = [ dependencies = [
"futures-core", "futures-core",
"tokio 1.40.0", "tokio 1.41.0",
"tokio-uring", "tokio-uring",
] ]
@ -153,7 +153,7 @@ dependencies = [
"futures-util", "futures-util",
"mio 1.0.2", "mio 1.0.2",
"socket2 0.5.7", "socket2 0.5.7",
"tokio 1.40.0", "tokio 1.41.0",
"tokio-uring", "tokio-uring",
"tracing", "tracing",
] ]
@ -356,7 +356,7 @@ dependencies = [
"futures-core", "futures-core",
"memchr", "memchr",
"pin-project-lite", "pin-project-lite",
"tokio 1.40.0", "tokio 1.41.0",
] ]
[[package]] [[package]]
@ -713,7 +713,7 @@ dependencies = [
"futures-core", "futures-core",
"memchr", "memchr",
"pin-project-lite", "pin-project-lite",
"tokio 1.40.0", "tokio 1.41.0",
"tokio-util", "tokio-util",
] ]
@ -1020,11 +1020,12 @@ dependencies = [
[[package]] [[package]]
name = "dashmap" name = "dashmap"
version = "5.5.3" version = "6.1.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "978747c1d849a7d2ee5e8adc0159961c48fb7e5db2f06af6723b80123bb53856" checksum = "5041cc499144891f3790297212f32a74fb938e5136a14943f338ef9e0ae276cf"
dependencies = [ dependencies = [
"cfg-if 1.0.0", "cfg-if 1.0.0",
"crossbeam-utils 0.8.20",
"hashbrown 0.14.5", "hashbrown 0.14.5",
"lock_api 0.4.12", "lock_api 0.4.12",
"once_cell", "once_cell",
@ -1343,9 +1344,9 @@ dependencies = [
[[package]] [[package]]
name = "futures-channel" name = "futures-channel"
version = "0.3.30" version = "0.3.31"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "eac8f7d7865dcb88bd4373ab671c8cf4508703796caa2b1985a9ca867b3fcb78" checksum = "2dff15bf788c671c1934e366d07e30c1814a8ef514e1af724a602e8a2fbe1b10"
dependencies = [ dependencies = [
"futures-core", "futures-core",
"futures-sink", "futures-sink",
@ -1353,9 +1354,9 @@ dependencies = [
[[package]] [[package]]
name = "futures-core" name = "futures-core"
version = "0.3.30" version = "0.3.31"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "dfc6580bb841c5a68e9ef15c77ccc837b40a7504914d52e47b8b0e9bbda25a1d" checksum = "05f29059c0c2090612e8d742178b0580d2dc940c837851ad723096f87af6663e"
[[package]] [[package]]
name = "futures-cpupool" name = "futures-cpupool"
@ -1380,15 +1381,15 @@ dependencies = [
[[package]] [[package]]
name = "futures-io" name = "futures-io"
version = "0.3.30" version = "0.3.31"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "a44623e20b9681a318efdd71c299b6b222ed6f231972bfe2f224ebad6311f0c1" checksum = "9e5c1b78ca4aae1ac06c48a526a655760685149f0d465d21f37abfe57ce075c6"
[[package]] [[package]]
name = "futures-macro" name = "futures-macro"
version = "0.3.30" version = "0.3.31"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "87750cf4b7a4c0625b1529e4c543c2182106e4dedc60a2a6455e00d212c489ac" checksum = "162ee34ebcb7c64a8abebc059ce0fee27c2262618d7b60ed8faf72fef13c3650"
dependencies = [ dependencies = [
"proc-macro2 1.0.86", "proc-macro2 1.0.86",
"quote 1.0.37", "quote 1.0.37",
@ -1397,15 +1398,15 @@ dependencies = [
[[package]] [[package]]
name = "futures-sink" name = "futures-sink"
version = "0.3.30" version = "0.3.31"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "9fb8e00e87438d937621c1c6269e53f536c14d3fbd6a042bb24879e57d474fb5" checksum = "e575fab7d1e0dcb8d0c7bcf9a63ee213816ab51902e6d244a95819acacf1d4f7"
[[package]] [[package]]
name = "futures-task" name = "futures-task"
version = "0.3.30" version = "0.3.31"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "38d84fa142264698cdce1a9f9172cf383a0c82de1bddcf3092901442c4097004" checksum = "f90f7dce0722e95104fcb095585910c0977252f286e354b5e3bd38902cd99988"
[[package]] [[package]]
name = "futures-timer" name = "futures-timer"
@ -1415,9 +1416,9 @@ checksum = "f288b0a4f20f9a56b5d1da57e2227c661b7b16168e2f72365f57b63326e29b24"
[[package]] [[package]]
name = "futures-util" name = "futures-util"
version = "0.3.30" version = "0.3.31"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "3d6401deb83407ab3da39eba7e33987a73c3df0c82b4bb5813ee871c19c41d48" checksum = "9fa08315bb612088cc391249efdc3bc77536f16c91f6cf495e6fbe85b20a4a81"
dependencies = [ dependencies = [
"futures-channel", "futures-channel",
"futures-core", "futures-core",
@ -1478,14 +1479,15 @@ checksum = "32085ea23f3234fc7846555e85283ba4de91e21016dc0455a16286d87a292d64"
[[package]] [[package]]
name = "governor" name = "governor"
version = "0.6.3" version = "0.7.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "68a7f542ee6b35af73b06abc0dad1c1bae89964e4e253bc4b587b91c9637867b" checksum = "0746aa765db78b521451ef74221663b57ba595bf83f75d0ce23cc09447c8139f"
dependencies = [ dependencies = [
"cfg-if 1.0.0", "cfg-if 1.0.0",
"dashmap", "dashmap",
"futures 0.3.30", "futures-sink",
"futures-timer", "futures-timer",
"futures-util",
"no-std-compat", "no-std-compat",
"nonzero_ext", "nonzero_ext",
"parking_lot 0.12.3", "parking_lot 0.12.3",
@ -1528,7 +1530,7 @@ dependencies = [
"http 1.1.0", "http 1.1.0",
"indexmap 2.5.0", "indexmap 2.5.0",
"slab", "slab",
"tokio 1.40.0", "tokio 1.41.0",
"tokio-util", "tokio-util",
"tracing", "tracing",
] ]
@ -1746,7 +1748,7 @@ dependencies = [
"itoa 1.0.11", "itoa 1.0.11",
"pin-project-lite", "pin-project-lite",
"smallvec 1.13.2", "smallvec 1.13.2",
"tokio 1.40.0", "tokio 1.41.0",
"want 0.3.1", "want 0.3.1",
] ]
@ -1762,7 +1764,7 @@ dependencies = [
"hyper-util", "hyper-util",
"rustls", "rustls",
"rustls-pki-types", "rustls-pki-types",
"tokio 1.40.0", "tokio 1.41.0",
"tokio-rustls", "tokio-rustls",
"tower-service", "tower-service",
"webpki-roots", "webpki-roots",
@ -1795,7 +1797,7 @@ dependencies = [
"hyper 1.4.1", "hyper 1.4.1",
"pin-project-lite", "pin-project-lite",
"socket2 0.5.7", "socket2 0.5.7",
"tokio 1.40.0", "tokio 1.41.0",
"tower-service", "tower-service",
"tracing", "tracing",
] ]
@ -2905,7 +2907,7 @@ dependencies = [
"rustls", "rustls",
"socket2 0.5.7", "socket2 0.5.7",
"thiserror", "thiserror",
"tokio 1.40.0", "tokio 1.41.0",
"tracing", "tracing",
] ]
@ -3148,7 +3150,7 @@ dependencies = [
"percent-encoding 2.3.1", "percent-encoding 2.3.1",
"pin-project-lite", "pin-project-lite",
"ryu", "ryu",
"tokio 1.40.0", "tokio 1.41.0",
"tokio-retry", "tokio-retry",
"tokio-util", "tokio-util",
"url 2.5.2", "url 2.5.2",
@ -3271,8 +3273,9 @@ dependencies = [
"serde_json", "serde_json",
"serde_urlencoded 0.7.1", "serde_urlencoded 0.7.1",
"sync_wrapper", "sync_wrapper",
"tokio 1.40.0", "tokio 1.41.0",
"tokio-rustls", "tokio-rustls",
"tokio-socks",
"tokio-util", "tokio-util",
"tower-service", "tower-service",
"url 2.5.2", "url 2.5.2",
@ -3993,9 +3996,9 @@ dependencies = [
[[package]] [[package]]
name = "tokio" name = "tokio"
version = "1.40.0" version = "1.41.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "e2b070231665d27ad9ec9b8df639893f46727666c6767db40317fbe920a5d998" checksum = "145f3413504347a2be84393cc8a7d2fb4d863b375909ea59f2158261aa258bbb"
dependencies = [ dependencies = [
"backtrace", "backtrace",
"bytes 1.7.2", "bytes 1.7.2",
@ -4089,7 +4092,7 @@ checksum = "7f57eb36ecbe0fc510036adff84824dd3c24bb781e21bfa67b69d556aa85214f"
dependencies = [ dependencies = [
"pin-project", "pin-project",
"rand 0.8.5", "rand 0.8.5",
"tokio 1.40.0", "tokio 1.41.0",
] ]
[[package]] [[package]]
@ -4100,7 +4103,19 @@ checksum = "0c7bc40d0e5a97695bb96e27995cd3a08538541b0a846f65bba7a359f36700d4"
dependencies = [ dependencies = [
"rustls", "rustls",
"rustls-pki-types", "rustls-pki-types",
"tokio 1.40.0", "tokio 1.41.0",
]
[[package]]
name = "tokio-socks"
version = "0.5.2"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "0d4770b8024672c1101b3f6733eab95b18007dbe0847a8afe341fcf79e06043f"
dependencies = [
"either",
"futures-util",
"thiserror",
"tokio 1.41.0",
] ]
[[package]] [[package]]
@ -4167,7 +4182,7 @@ dependencies = [
"libc", "libc",
"slab", "slab",
"socket2 0.4.10", "socket2 0.4.10",
"tokio 1.40.0", "tokio 1.41.0",
] ]
[[package]] [[package]]
@ -4180,7 +4195,7 @@ dependencies = [
"futures-core", "futures-core",
"futures-sink", "futures-sink",
"pin-project-lite", "pin-project-lite",
"tokio 1.40.0", "tokio 1.41.0",
] ]
[[package]] [[package]]
@ -4549,7 +4564,7 @@ dependencies = [
"stop-words", "stop-words",
"tempfile", "tempfile",
"thesaurus", "thesaurus",
"tokio 1.40.0", "tokio 1.41.0",
] ]
[[package]] [[package]]

View File

@ -20,7 +20,7 @@ reqwest = { version = "0.12.5", default-features = false, features = [
"http2", "http2",
"socks", "socks",
] } ] }
tokio = { version = "1.32.0", features = [ tokio = { version = "1.41.0", features = [
"rt-multi-thread", "rt-multi-thread",
"macros", "macros",
"fs", "fs",
@ -62,7 +62,7 @@ futures = { version = "0.3.30", default-features = false, features = ["alloc"] }
dhat = { version = "0.3.2", optional = true, default-features = false } dhat = { version = "0.3.2", optional = true, default-features = false }
mimalloc = { version = "0.1.43", default-features = false } mimalloc = { version = "0.1.43", default-features = false }
async-once-cell = { version = "0.5.3", default-features = false } async-once-cell = { version = "0.5.3", default-features = false }
actix-governor = { version = "0.6.0", default-features = false } actix-governor = { version = "0.7.0", default-features = false }
moka = { version = "0.12.8", optional = true, default-features = false, features = [ moka = { version = "0.12.8", optional = true, default-features = false, features = [
"future", "future",
] } ] }

View File

@ -1,41 +1,6 @@
/**
* Selects the input element for the search box
* @type {HTMLInputElement}
*/
const searchBox = document.querySelector('input')
/**
* Redirects the user to the search results page with the query parameter
*/
function searchWeb() {
const query = searchBox.value.trim()
try {
let safeSearchLevel = document.querySelector('.search_options select').value
if (query) {
window.location.href = `search?q=${encodeURIComponent(
query,
)}&safesearch=${encodeURIComponent(safeSearchLevel)}`
}
} catch (error) {
if (query) {
window.location.href = `search?q=${encodeURIComponent(query)}`
}
}
}
/**
* Listens for the 'Enter' key press event on the search box and calls the searchWeb function
* @param {KeyboardEvent} e - The keyboard event object
*/
searchBox.addEventListener('keyup', (e) => {
if (e.key === 'Enter') {
searchWeb()
}
})
/** /**
* A function that clears the search input text when the clear button is clicked. * A function that clears the search input text when the clear button is clicked.
*/ */
function clearSearchText() { function clearSearchText() {
document.querySelector('.search_bar input').value = '' document.querySelector('.search_bar > input').value = ''
} }

View File

@ -1,39 +0,0 @@
/**
* Navigates to the next page by incrementing the current page number in the URL query string.
* @returns {void}
*/
function navigate_forward() {
let url = new URL(window.location);
let searchParams = url.searchParams;
let q = searchParams.get('q');
let page = parseInt(searchParams.get('page'));
if (isNaN(page)) {
page = 1;
} else {
page++;
}
window.location.href = `${url.origin}${url.pathname}?q=${encodeURIComponent(q)}&page=${page}`;
}
/**
* Navigates to the previous page by decrementing the current page number in the URL query string.
* @returns {void}
*/
function navigate_backward() {
let url = new URL(window.location);
let searchParams = url.searchParams;
let q = searchParams.get('q');
let page = parseInt(searchParams.get('page'));
if (isNaN(page)) {
page = 0;
} else if (page > 0) {
page--;
}
window.location.href = `${url.origin}${url.pathname}?q=${encodeURIComponent(q)}&page=${page}`;
}

View File

@ -1,18 +0,0 @@
document.addEventListener(
'DOMContentLoaded',
() => {
let url = new URL(window.location)
let searchParams = url.searchParams
let safeSearchLevel = searchParams.get('safesearch')
if (
safeSearchLevel >= 0 &&
safeSearchLevel <= 2 &&
safeSearchLevel !== null
) {
document.querySelector('.search_options select').value = safeSearchLevel
}
},
false,
)

View File

@ -448,7 +448,7 @@ footer div {
align-items: center; align-items: center;
} }
.page_navigation button { .page_navigation a {
background: var(--background-color); background: var(--background-color);
color: var(--foreground-color); color: var(--foreground-color);
padding: 1rem; padding: 1rem;
@ -457,7 +457,7 @@ footer div {
border: none; border: none;
} }
.page_navigation button:active { .page_navigation a:active {
filter: brightness(1.2); filter: brightness(1.2);
} }

View File

@ -129,6 +129,7 @@ pub async fn search(
&config.style.theme, &config.style.theme,
&config.style.animation, &config.style.animation,
query, query,
page,
&results.0, &results.0,
) )
.0, .0,

View File

@ -14,12 +14,13 @@ use maud::{html, Markup, PreEscaped};
/// It returns the compiled html code for the search bar as a result. /// It returns the compiled html code for the search bar as a result.
pub fn bar(query: &str) -> Markup { pub fn bar(query: &str) -> Markup {
html!( html!(
(PreEscaped("<form action=\"/search\">"))
(PreEscaped("<div class=\"search_bar\">")) (PreEscaped("<div class=\"search_bar\">"))
input type="search" name="search-box" value=(query) placeholder="Type to search"; input type="search" name="q" value=(query) placeholder="Type to search";
button type="reset" onclick="clearSearchText()" { button type="button" onclick="clearSearchText()" {
img src="./images/close.svg" alt="Clear button icon for clearing search input text"; img src="./images/close.svg" alt="Clear button icon for clearing search input text";
} }
button type="submit" onclick="searchWeb()" { button type="submit" {
img src="./images/magnifying_glass.svg" alt="Info icon for error box"; img src="./images/magnifying_glass.svg" alt="Info icon for error box";
} }
) )

View File

@ -29,7 +29,7 @@ pub fn search_bar(
(bar(query)) (bar(query))
.error_box { .error_box {
@if !engine_errors_info.is_empty(){ @if !engine_errors_info.is_empty(){
button onclick="toggleErrorBox()" class="error_box_toggle_button"{ button type="button" onclick="toggleErrorBox()" class="error_box_toggle_button"{
img src="./images/warning.svg" alt="Info icon for error box"; img src="./images/warning.svg" alt="Info icon for error box";
} }
.dropdown_error_box{ .dropdown_error_box{
@ -43,7 +43,7 @@ pub fn search_bar(
} }
} }
@else { @else {
button onclick="toggleErrorBox()" class="error_box_toggle_button"{ button type="button" onclick="toggleErrorBox()" class="error_box_toggle_button"{
img src="./images/info.svg" alt="Warning icon for error box"; img src="./images/info.svg" alt="Warning icon for error box";
} }
.dropdown_error_box { .dropdown_error_box {
@ -56,10 +56,10 @@ pub fn search_bar(
(PreEscaped("</div>")) (PreEscaped("</div>"))
.search_options { .search_options {
@if safe_search_level >= 3 { @if safe_search_level >= 3 {
(PreEscaped("<select name=\"safe_search_levels\" disabled>")) (PreEscaped("<select name=\"safesearch\" disabled>"))
} }
@else{ @else{
(PreEscaped("<select name=\"safe_search_levels\">")) (PreEscaped(format!("<select name=\"safesearch\" value=\"{}\">", safe_search_level)))
} }
@for (idx, name) in SAFE_SEARCH_LEVELS_NAME.iter().enumerate() { @for (idx, name) in SAFE_SEARCH_LEVELS_NAME.iter().enumerate() {
@if (safe_search_level as usize) == idx { @if (safe_search_level as usize) == idx {
@ -71,6 +71,7 @@ pub fn search_bar(
} }
(PreEscaped("</select>")) (PreEscaped("</select>"))
} }
(PreEscaped("</form>"))
} }
) )
} }

View File

@ -24,6 +24,7 @@ pub fn search(
theme: &str, theme: &str,
animation: &Option<String>, animation: &Option<String>,
query: &str, query: &str,
page: u32,
search_results: &SearchResults, search_results: &SearchResults,
) -> Markup { ) -> Markup {
html!( html!(
@ -108,15 +109,14 @@ pub fn search(
} }
} }
.page_navigation { .page_navigation {
button type="button" onclick="navigate_backward()"{ a href=(format!("/search?q={}&safesearch={}&page={}", query, search_results.safe_search_level, if page > 1 {page-1} else {1})) {
(PreEscaped("&#8592;")) "previous" (PreEscaped("&#8592;")) "previous"
} }
button type="button" onclick="navigate_forward()"{"next" (PreEscaped("&#8594;"))} a href=(format!("/search?q={}&safesearch={}&page={}", query, search_results.safe_search_level, page+2)) {
"next" (PreEscaped("&#8594;"))}
} }
} }
script src="static/index.js"{} script src="static/index.js"{}
script src="static/search_area_options.js"{}
script src="static/pagination.js"{}
script src="static/error_box.js"{} script src="static/error_box.js"{}
(footer()) (footer())
) )