only show non-placed boats in boathouse list

This commit is contained in:
philipp 2024-04-13 09:42:12 +02:00
parent 3b04b39d66
commit cfc35fbec6
2 changed files with 21 additions and 1 deletions

View File

@ -5,6 +5,8 @@ use rocket::serde::{Deserialize, Serialize};
use rocket::FromForm; use rocket::FromForm;
use sqlx::{FromRow, Sqlite, SqlitePool, Transaction}; use sqlx::{FromRow, Sqlite, SqlitePool, Transaction};
use crate::model::boathouse::Boathouse;
use super::location::Location; use super::location::Location;
use super::user::User; use super::user::User;
@ -357,6 +359,17 @@ ORDER BY amount_seats DESC
.await .await
.unwrap(); //Okay, because we can only create a Boat of a valid id .unwrap(); //Okay, because we can only create a Boat of a valid id
} }
pub async fn boathouse(&self, db: &SqlitePool) -> Option<Boathouse> {
sqlx::query_as!(
Boathouse,
"SELECT * FROM boathouse WHERE boat_id like ?",
self.id
)
.fetch_one(db)
.await
.ok()
}
} }
#[cfg(test)] #[cfg(test)]

View File

@ -25,7 +25,14 @@ async fn index(
} }
let boats = Boat::all_for_boatshouse(db).await; let boats = Boat::all_for_boatshouse(db).await;
context.insert("boats", &boats); let mut final_boats = Vec::new();
for boat in boats {
if boat.boat.boathouse(db).await.is_none() {
final_boats.push(boat);
}
}
context.insert("boats", &final_boats);
let boathouse = Boathouse::get(db).await; let boathouse = Boathouse::get(db).await;
context.insert("boathouse", &boathouse); context.insert("boathouse", &boathouse);