aboutsummaryrefslogtreecommitdiff
path: root/src/database.rs
diff options
context:
space:
mode:
authorjvech <jmvalenciae@unal.edu.co>2024-04-28 22:53:50 -0500
committerjvech <jmvalenciae@unal.edu.co>2024-04-28 22:53:50 -0500
commita361eb833f516befe79b45a8b6ed3162a21bc06a (patch)
tree71c2228f2159e09351c778076354c872a1a8d433 /src/database.rs
parentac7bcafae3b9cdb75a9df35a9ab8e37adb1eb192 (diff)
add: view subcommand implemented
Diffstat (limited to 'src/database.rs')
-rw-r--r--src/database.rs65
1 files changed, 63 insertions, 2 deletions
diff --git a/src/database.rs b/src/database.rs
index 8321723..14f04d9 100644
--- a/src/database.rs
+++ b/src/database.rs
@@ -1,5 +1,4 @@
-use rusqlite::Connection;
-use rusqlite::Result;
+use rusqlite::{Connection, Result, Rows, Statement};
use rusqlite::config::DbConfig::{*};
use chrono::Utc;
use std::path::PathBuf;
@@ -46,6 +45,68 @@ impl Database {
Ok(())
}
+ pub fn view_history(filepath: &PathBuf, filter: Option<String>) -> Result<()> {
+ let conn = Connection::open(filepath)?;
+ let mut hist_query: String = "
+ SELECT date(r.register_date, 'auto'), a.name, r.amount
+ FROM Registers r
+ INNER JOIN Agents a
+ ON a.id = r.agent_id
+ ".to_owned();
+
+ let mut stmt: Statement;
+ let mut regs: Rows;
+
+ match filter {
+ Some(name) => {
+ hist_query.push_str("WHERE name = ?1");
+ stmt = conn.prepare(hist_query.as_str())?;
+ regs = stmt.query([name])?;
+ },
+ None => {
+ stmt = conn.prepare(hist_query.as_str())?;
+ regs = stmt.query([])?;
+ }
+ };
+ let mut total = 0;
+ println!("+{:-<10}+{:-<20}+{:-<10}+", "", "", "");
+ println!("|{:^10}|{:^20}|{:^10}|", "date", "name", "amount");
+ println!("+{:-<10}+{:-<20}+{:-<10}+", "", "", "");
+ while let Some(row) = regs.next()? {
+ let date: String = row.get(0)?;
+ let name: String = row.get(1)?;
+ let amount: i32 = row.get(2)?;
+
+ println!("|{}|{:>20}|{:>10}|", date, name, amount);
+ total += amount;
+ }
+ println!("+{:-<10}+{:-<20}+{:-<10}+", "", "", "");
+ println!("|{:^10}{:>32}|", "total", total);
+ println!("+{:-<10}+{:-<20}+{:-<10}+", "", "", "");
+ Ok(())
+ }
+
+ pub fn view_total(filepath: &PathBuf) -> Result<()> {
+ let conn = Connection::open(filepath)?;
+ let mut stmt = conn.prepare("
+ SELECT a.name, sum(r.amount)
+ FROM Registers r
+ INNER JOIN Agents a
+ ON a.id = r.agent_id
+ GROUP BY a.name")?;
+ let mut agents = stmt.query([])?;
+ println!("+{:->20}+{:->11}+", "", "");
+ println!("|{:^20}| {:^10}|", "name", "amount");
+ println!("+{:->20}+{:->11}+", "", "");
+ while let Some(row) = agents.next()? {
+ let name: String = row.get(0)?;
+ let amount: i32 = row.get(1)?;
+ println!("|{:>20}| {:>10}|", name, amount);
+ }
+ println!("+{:->20}+{:->11}+", "", "");
+ Ok(())
+ }
+
pub fn init_database(filepath: &PathBuf) -> Result<()> {
let conn = Connection::open(filepath).expect("Database file creation Error");
conn.execute("
Feel free to download, copy and edit any repo