|
|
@ -1,4 +1,10 @@
|
|
|
|
use crate::utils::date::LocalDate;
|
|
|
|
use crate::bibliography::keys::{
|
|
|
|
|
|
|
|
K_ADDRESS, K_AUTHOR, K_DATE, K_EDITION, K_PUBLISHER, K_SERIES, K_TITLE, K_VOLUME,
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
use crate::bibliography::FromHashMap;
|
|
|
|
|
|
|
|
use crate::utils::date::{parse_date, LocalDate};
|
|
|
|
|
|
|
|
use std::collections::hash_map::RandomState;
|
|
|
|
|
|
|
|
use std::collections::HashMap;
|
|
|
|
|
|
|
|
|
|
|
|
/// Source that is part of a book
|
|
|
|
/// Source that is part of a book
|
|
|
|
#[derive(Clone, Debug)]
|
|
|
|
#[derive(Clone, Debug)]
|
|
|
@ -36,3 +42,35 @@ impl InBook {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
impl FromHashMap for InBook {
|
|
|
|
|
|
|
|
fn from_hash_map(map: &HashMap<String, String, RandomState>) -> Option<Box<Self>> {
|
|
|
|
|
|
|
|
let author = map.get(K_AUTHOR)?;
|
|
|
|
|
|
|
|
let title = map.get(K_TITLE)?;
|
|
|
|
|
|
|
|
let position = map.get(K_TITLE)?;
|
|
|
|
|
|
|
|
let publisher = map.get(K_PUBLISHER)?;
|
|
|
|
|
|
|
|
let date = parse_date(map.get(K_DATE)?)?;
|
|
|
|
|
|
|
|
let mut in_book = InBook::new(
|
|
|
|
|
|
|
|
author.clone(),
|
|
|
|
|
|
|
|
title.clone(),
|
|
|
|
|
|
|
|
position.clone(),
|
|
|
|
|
|
|
|
publisher.clone(),
|
|
|
|
|
|
|
|
date,
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if let Some(volume) = map.get(K_VOLUME) {
|
|
|
|
|
|
|
|
in_book.volume = Some(volume.clone());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if let Some(series) = map.get(K_SERIES) {
|
|
|
|
|
|
|
|
in_book.series = Some(series.clone());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if let Some(address) = map.get(K_ADDRESS) {
|
|
|
|
|
|
|
|
in_book.address = Some(address.clone());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if let Some(edition) = map.get(K_EDITION) {
|
|
|
|
|
|
|
|
in_book.edition = Some(edition.clone())
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Some(Box::new(in_book))
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|