Compare commits
2 Commits
0de83070c7
...
4c45fba5f6
Author | SHA1 | Date |
---|---|---|
Augusto Gunsch | 4c45fba5f6 | |
Augusto Gunsch | 77bc2f9b41 |
File diff suppressed because it is too large
Load Diff
10
src/views.rs
10
src/views.rs
|
@ -12,15 +12,15 @@ use crate::language::Language;
|
||||||
use crate::FRONTEND_DIR;
|
use crate::FRONTEND_DIR;
|
||||||
|
|
||||||
#[get("/")]
|
#[get("/")]
|
||||||
pub fn frontend() -> content::Html<String> {
|
pub fn frontend() -> content::RawHtml<String> {
|
||||||
match fs::read_to_string(&format!("{}/{}", FRONTEND_DIR, "index.html")) {
|
match fs::read_to_string(&format!("{}/{}", FRONTEND_DIR, "index.html")) {
|
||||||
Ok(file) => content::Html(file),
|
Ok(file) => content::RawHtml(file),
|
||||||
Err(_) => content::Html(String::from("<h1>No web frontend installed.</h1>"))
|
Err(_) => content::RawHtml(String::from("<h1>No web frontend installed.</h1>"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[get("/langs/<lang>/words/<word>")]
|
#[get("/langs/<lang>/words/<word>")]
|
||||||
pub fn get_entries(db: &State<WordDb>, lang: &str, word: &str) -> status::Custom<content::Json<String>> {
|
pub fn get_entries(db: &State<WordDb>, lang: &str, word: &str) -> status::Custom<content::RawJson<String>> {
|
||||||
let conn = db.connect();
|
let conn = db.connect();
|
||||||
|
|
||||||
let mut statement = conn.prepare(&format!(
|
let mut statement = conn.prepare(&format!(
|
||||||
|
@ -46,7 +46,7 @@ pub fn get_entries(db: &State<WordDb>, lang: &str, word: &str) -> status::Custom
|
||||||
}
|
}
|
||||||
words.push(']');
|
words.push(']');
|
||||||
|
|
||||||
status::Custom(Status::Ok, content::Json(words))
|
status::Custom(Status::Ok, content::RawJson(words))
|
||||||
}
|
}
|
||||||
|
|
||||||
#[get("/langs/<lang>/words?<like>&<limit>&<offset>")]
|
#[get("/langs/<lang>/words?<like>&<limit>&<offset>")]
|
||||||
|
|
|
@ -184,7 +184,12 @@ $(document).ready(() => {
|
||||||
html += `<h1>Not found: <mark>${decodeURIComponent(word)}</mark></h1>`;
|
html += `<h1>Not found: <mark>${decodeURIComponent(word)}</mark></h1>`;
|
||||||
} else {
|
} else {
|
||||||
data.forEach(entry => {
|
data.forEach(entry => {
|
||||||
html += `<h1>${entry.word} <span class="pos">${entry.sounds[0].ipa} (${entry.pos})</span></h1>`
|
html += `<h1>${entry.word} <span class="pos">(${entry.pos})</span></h1>`
|
||||||
|
|
||||||
|
if('sounds' in entry) {
|
||||||
|
html += `<p>${entry.sounds.map(sound => sound.ipa).join(', ')}</p>`;
|
||||||
|
}
|
||||||
|
|
||||||
if('senses' in entry) {
|
if('senses' in entry) {
|
||||||
let tags = [];
|
let tags = [];
|
||||||
entry.senses.forEach(sense => {
|
entry.senses.forEach(sense => {
|
||||||
|
@ -228,7 +233,7 @@ $(document).ready(() => {
|
||||||
if('forms' in entry) {
|
if('forms' in entry) {
|
||||||
if(entry.pos === 'verb') {
|
if(entry.pos === 'verb') {
|
||||||
let conjugation = entry.forms.filter(form =>
|
let conjugation = entry.forms.filter(form =>
|
||||||
'source' in form && form.source === 'Conjugation');
|
'source' in form && form.source === 'conjugation');
|
||||||
|
|
||||||
if(conjugation.length > 0) {
|
if(conjugation.length > 0) {
|
||||||
html += '<h2>Conjugation</h2>';
|
html += '<h2>Conjugation</h2>';
|
||||||
|
@ -237,7 +242,7 @@ $(document).ready(() => {
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
let declension = entry.forms.filter(form =>
|
let declension = entry.forms.filter(form =>
|
||||||
'source' in form && form.source === 'Declension');
|
'source' in form && form.source === 'declension');
|
||||||
|
|
||||||
if(declension.length > 0) {
|
if(declension.length > 0) {
|
||||||
html += '<h2>Declension</h2>';
|
html += '<h2>Declension</h2>';
|
||||||
|
|
Loading…
Reference in New Issue