aboutsummaryrefslogtreecommitdiff
path: root/src/modules/router/module.rs
diff options
context:
space:
mode:
authorFuwn <[email protected]>2023-03-30 17:43:44 -0700
committerFuwn <[email protected]>2023-03-30 17:43:44 -0700
commit8834497c15643ef8aa4117d6f9f07eb692cb1162 (patch)
tree05899321fe5d4f31aa7087faeeaec0dba1f2cf57 /src/modules/router/module.rs
parentfeat(router): add translation engine (diff)
downloadlocus-8834497c15643ef8aa4117d6f9f07eb692cb1162.tar.xz
locus-8834497c15643ef8aa4117d6f9f07eb692cb1162.zip
refactor(router): move ticker and translate to modules
Diffstat (limited to 'src/modules/router/module.rs')
-rw-r--r--src/modules/router/module.rs62
1 files changed, 2 insertions, 60 deletions
diff --git a/src/modules/router/module.rs b/src/modules/router/module.rs
index a97c973..1987568 100644
--- a/src/modules/router/module.rs
+++ b/src/modules/router/module.rs
@@ -16,8 +16,6 @@
// Copyright (C) 2022-2022 Fuwn <[email protected]>
// SPDX-License-Identifier: GPL-3.0-only
-use crate::{modules::router::deepl::translate, DATABASE};
-
pub fn module(router: &mut windmark::Router) {
router.set_pre_route_callback(Box::new(|context| {
info!(
@@ -26,28 +24,7 @@ pub fn module(router: &mut windmark::Router) {
context.url.to_string(),
);
- let url_path = if context.url.path().is_empty() {
- "/"
- } else {
- context.url.path()
- };
-
- let previous_database = (*DATABASE.lock().unwrap()).get::<i32>(url_path);
-
- match previous_database {
- None => {
- (*DATABASE.lock().unwrap())
- .set::<i32>(url_path, &0)
- .unwrap();
- }
- Some(_) => {}
- }
-
- let new_database = (*DATABASE.lock().unwrap()).get::<i32>(url_path);
-
- (*DATABASE.lock().unwrap())
- .set(url_path, &(new_database.unwrap() + 1))
- .unwrap();
+ super::ticker::module(&context);
}));
router.set_post_route_callback(Box::new({
|context, content| {
@@ -57,42 +34,7 @@ pub fn module(router: &mut windmark::Router) {
context.url.to_string(),
);
- if let Some(language) =
- windmark::utilities::queries_from_url(context.url).get("translate")
- {
- let mut lines = content
- .lines()
- .map(ToString::to_string)
- .collect::<Vec<String>>();
- let mut preformatted = true;
-
- for line in &mut lines {
- if line == "```" {
- preformatted = !preformatted;
- }
-
- if line.starts_with("=>") {
- if let Some(germ::ast::Node::Link {
- to,
- text,
- }) = germ::ast::Ast::from_string(line).inner().get(0)
- {
- *line = format!(
- "=> {to}?translate={language}{}",
- text.clone().map_or_else(
- || "".to_string(),
- |text| { format!(" {}", translate(&text, language).text()) }
- )
- );
- }
- } else if !line.starts_with("=>") && preformatted && !line.is_empty()
- {
- *line = translate(line, language).text();
- }
- }
-
- *content = lines.join("\n");
- }
+ super::translate::module(&context, content);
}
}));
}