show registration time for rowers

This commit is contained in:
2023-04-05 17:25:22 +02:00
parent 80976058b9
commit f7c7f9aaf8
3 changed files with 36 additions and 27 deletions

View File

@ -2,6 +2,8 @@ use chrono::NaiveDate;
use serde::Serialize;
use sqlx::SqlitePool;
use super::planned_event::Registration;
#[derive(Serialize, Clone)]
pub struct Trip {
id: i64,
@ -18,7 +20,7 @@ pub struct Trip {
pub struct TripWithUser {
#[serde(flatten)]
trip: Trip,
rower: Vec<String>,
rower: Vec<Registration>,
}
impl Trip {
@ -48,18 +50,19 @@ WHERE day=?
ret
}
async fn get_all_rower_for_id(db: &SqlitePool, id: i64) -> Vec<String> {
let res = sqlx::query!(
async fn get_all_rower_for_id(db: &SqlitePool, id: i64) -> Vec<Registration> {
sqlx::query_as!(
Registration,
"
SELECT (SELECT name FROM user WHERE user_trip.user_id = user.id) as name FROM user_trip WHERE trip_details_id = (SELECT trip_details_id FROM trip WHERE id = ?)
",
SELECT
(SELECT name FROM user WHERE user_trip.user_id = user.id) as name,
(SELECT created_at FROM user WHERE user_trip.user_id = user.id) as registered_at
FROM user_trip WHERE trip_details_id = (SELECT trip_details_id FROM trip WHERE id = ?)",
id
)
.fetch_all(db)
.await
.unwrap(); //TODO: fixme
res.into_iter().map(|x| x.name).collect()
.unwrap() //TODO: fixme
}
pub async fn new_own(db: &SqlitePool, cox_id: i64, trip_details_id: i64) {