1
0
mirror of https://github.com/scoobybejesus/cryptools.git synced 2025-04-04 04:20:27 +00:00
cryptools-mirror/src/mytui/app.rs
2023-10-19 17:17:51 -04:00

245 lines
7.2 KiB
Rust

// Copyright (c) 2017-2023, scoobybejesus
// Redistributions must include the license: https://github.com/scoobybejesus/cryptools/blob/master/LEGAL.txt
use std::error::Error;
use std::collections::HashMap;
use crptls::transaction::{Transaction, ActionRecord};
use crptls::account::{Account, RawAccount};
use crptls::core_functions::ImportProcessParameters;
use crate::export::{export_csv, export_je, export_txt};
pub (crate) const REPORTS: [&'static str; 11] = [
"1. CSV: Account Sums",
"2. CSV: Account Sums (Non-zero only)",
"3. CSV: Account Sums (Orig. basis vs like-kind basis)",
"4. CSV: Transactions by movement (every movement)",
"5. CSV: Transactions by movement (summarized by long-term/short-term)",
"6. CSV: Transactions by movement (every movement, w/ orig. and like-kind basis",
"7. CSV: Transactions summary by LT/ST for Form 8949",
"8. TXT: Accounts by lot (every movement)",
"9. TXT: Accounts by lot (every lot balance)",
"10. TXT: Accounts by lot (every non-zero lot balance)",
"11. TXT: Bookkeeping journal entries",
];
pub struct ListState<I> {
pub items: Vec<I>,
pub selected: usize,
}
impl<I> ListState<I> {
fn new(items: Vec<I>) -> ListState<I> {
ListState { items, selected: 0 }
}
fn select_previous(&mut self) {
if self.selected > 0 {
self.selected -= 1;
}
}
fn select_next(&mut self) {
if self.selected < self.items.len() - 1 {
self.selected += 1
}
}
}
pub struct PrintWindow<'a> {
pub title: &'a str,
pub should_quit: bool,
pub tasks: ListState<&'a str>,
pub to_print_by_idx: Vec<usize>,
pub to_print_by_title: Vec<&'a str>,
}
impl<'a> PrintWindow<'a> {
pub fn new(title: &'a str) -> PrintWindow<'a> {
PrintWindow {
title,
should_quit: false,
tasks: ListState::new(REPORTS.to_vec()),
to_print_by_idx: Vec::with_capacity(REPORTS.len()),
to_print_by_title: Vec::with_capacity(REPORTS.len()),
}
}
pub fn on_up(&mut self) {
self.tasks.select_previous();
}
pub fn on_down(&mut self) {
self.tasks.select_next();
}
pub fn on_key(&mut self, c: char) {
match c {
'q' => {
self.to_print_by_idx = Vec::with_capacity(0);
self.should_quit = true;
}
'p' => {
self.should_quit = true;
}
'x' => {
let selected = self.tasks.selected;
if self.to_print_by_idx.contains(&selected) {} else {
self.to_print_by_idx.push(selected);
self.to_print_by_title.push(self.tasks.items[selected])
}
Self::change_vecs_to_chrono_order(&mut self.to_print_by_idx, &mut self.to_print_by_title);
self.tasks.select_next();
}
'd' => {
let selected_idx = self.tasks.selected;
self.to_print_by_idx.retain(|&x| x != selected_idx );
let selected_str = self.tasks.items[selected_idx];
self.to_print_by_title.retain(|&x| x != selected_str );
self.tasks.select_previous();
}
_ => {}
}
}
fn change_vecs_to_chrono_order(vec: &mut Vec<usize>, strvec: &mut Vec<&str>) {
let length = vec.len();
for _ in 0..length {
for j in 0..length-1 {
if vec[j] > vec[j+1] {
vec.swap(j, j+1);
strvec.swap(j, j+1)
}
}
}
}
}
pub fn export(
app: &PrintWindow,
settings: &ImportProcessParameters,
raw_acct_map: &HashMap<u16, RawAccount>,
account_map: &HashMap<u16, Account>,
action_records_map: &HashMap<u32, ActionRecord>,
transactions_map: &HashMap<u32, Transaction>,
) -> Result<(), Box<dyn Error>> {
let reports = REPORTS.to_vec();
println!("Attempting to export:");
for report_idx in app.to_print_by_idx.iter() {
println!(" {}", reports[*report_idx]);
match report_idx + 1 {
1 => {
export_csv::_1_account_sums_to_csv(
&settings,
&raw_acct_map,
&account_map
);
}
2 => {
export_csv::_2_account_sums_nonzero_to_csv(
&settings,
&raw_acct_map,
&account_map,
);
}
3 => {
export_csv::_3_account_sums_to_csv_with_orig_basis(
&settings,
&raw_acct_map,
&account_map
);
}
4 => {
export_csv::_4_transaction_mvmt_detail_to_csv(
&settings,
&raw_acct_map,
&account_map,
&action_records_map,
&transactions_map
)?;
}
5 => {
export_csv::_5_transaction_mvmt_summaries_to_csv(
&settings,
&raw_acct_map,
&account_map,
&action_records_map,
&transactions_map
)?;
}
6 => {
export_csv::_6_transaction_mvmt_detail_to_csv_w_orig(
&settings,
&raw_acct_map,
&account_map,
&action_records_map,
&transactions_map
)?;
}
7 => {
export_csv::_7_gain_loss_8949_to_csv(
&settings,
&raw_acct_map,
&account_map,
&action_records_map,
&transactions_map
)?;
}
8 => {
export_txt::_1_account_lot_detail_to_txt(
&settings,
&raw_acct_map,
&account_map,
&action_records_map,
&transactions_map,
)?;
}
9 => {
export_txt::_2_account_lot_summary_to_txt(
&settings,
&raw_acct_map,
&account_map,
)?;
}
10 => {
export_txt::_3_account_lot_summary_non_zero_to_txt(
&settings,
&raw_acct_map,
&account_map,
)?;
}
11 => {
if !settings.lk_treatment_enabled {
export_je::prepare_non_lk_journal_entries(
&settings,
&raw_acct_map,
&account_map,
&action_records_map,
&transactions_map,
)?;
} else {
println!(" *Skipping non-like-kind report: {}", reports[*report_idx]);
}
}
_ => {}
}
}
println!("Successfully exported.");
Ok(())
}