Add CSV column mapping and reconstruction of basic information
This commit is contained in:
		
							parent
							
								
									8b2f0102c4
								
							
						
					
					
						commit
						82d9cf5c87
					
				
							
								
								
									
										45
									
								
								src/csv_parser.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								src/csv_parser.rs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,45 @@ | |||||||
|  | use chrono::{NaiveDate, NaiveTime}; | ||||||
|  | use csv::StringRecord; | ||||||
|  | use crate::utils::Result; | ||||||
|  | 
 | ||||||
|  | mod headings { | ||||||
|  |     pub const USER: usize = 1; | ||||||
|  |     pub const USER_EMAIL: usize = 2; | ||||||
|  |     pub const CLIENT_NAME: usize = 3; | ||||||
|  |     pub const PROJECT_NAME: usize = 4; | ||||||
|  |     pub const TASK_NAME: usize = 5; | ||||||
|  |     pub const DESCRIPTION: usize = 6; | ||||||
|  |     pub const BILLABLE: usize = 7; | ||||||
|  |     pub const START_DATE: usize = 8; | ||||||
|  |     pub const END_DATE: usize = 9; | ||||||
|  |     pub const START_TIME: usize = 10; | ||||||
|  |     pub const END_TIME: usize = 11; | ||||||
|  |     pub const DURATION: usize = 12; | ||||||
|  |     pub const TAGS: usize = 13; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | fn parse_csv_row(row: StringRecord) -> Result<crate::entity::time_entry::Model> { | ||||||
|  |     let start_date = row.get(headings::START_DATE).unwrap(); | ||||||
|  |     let start_time = row.get(headings::START_TIME).unwrap(); | ||||||
|  |     let end_date = row.get(headings::END_DATE).unwrap(); | ||||||
|  |     let end_time = row.get(headings::END_TIME).unwrap(); | ||||||
|  | 
 | ||||||
|  |     let start_time = NaiveTime::parse_from_str(start_time, "%H:%M:%S")?; | ||||||
|  |     let end_time = NaiveTime::parse_from_str(end_time, "%H:%M:%S")?; | ||||||
|  |     let start_date = NaiveDate::parse_from_str(start_date, "%Y-%m-%d")?; | ||||||
|  |     let end_date = NaiveDate::parse_from_str(end_date, "%Y-%m-%d")?; | ||||||
|  | 
 | ||||||
|  |     let start = start_date.and_time(start_time); | ||||||
|  |     let end = end_date.and_time(end_time); | ||||||
|  | 
 | ||||||
|  |     let description = row.get(headings::DESCRIPTION)?; | ||||||
|  |     let project_name = row.get(headings::PROJECT_NAME)?; | ||||||
|  |     let client_name = row.get(headings::CLIENT_NAME)?; | ||||||
|  |     let tags = row.get(headings::TAGS)?; | ||||||
|  |     let task_name = row.get(headings::TASK_NAME)?; | ||||||
|  |     let billable = match row.get(headings::BILLABLE)? { | ||||||
|  |         "Yes" => true, | ||||||
|  |         "No" => false, | ||||||
|  |         _ => unimplemented!("Unknown billable value") | ||||||
|  |     }; | ||||||
|  | } | ||||||
| @ -31,6 +31,7 @@ mod entity; | |||||||
| mod poll; | mod poll; | ||||||
| mod types; | mod types; | ||||||
| mod utils; | mod utils; | ||||||
|  | mod csv_parser; | ||||||
| 
 | 
 | ||||||
| #[derive(Debug, Clone, Parser)] | #[derive(Debug, Clone, Parser)] | ||||||
| struct Config { | struct Config { | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user