use std::collections::{HashMap, HashSet}; use seed::Url; use crate::{shopping_cart, I18n, Page}; #[derive(Debug)] pub struct Model { pub url: Url, pub token: Option, pub page: Page, pub logo: Option, pub shared: crate::shared::Model, pub i18n: I18n, pub cart: shopping_cart::ShoppingCart, pub config: Config, #[cfg(debug_assertions)] pub debug_modal: bool, } #[derive(Debug)] pub struct Config { pub pay_methods: Vec<::model::PaymentMethod>, pub coupons: bool, pub currency: &'static rusty_money::iso::Currency, } impl Default for Config { fn default() -> Self { Self { pay_methods: vec![], coupons: false, currency: rusty_money::iso::PLN, } } } impl From<::model::api::Config> for Config { fn from( model::api::Config { pay_methods, coupons, currency, }: model::api::Config, ) -> Self { Self { pay_methods, coupons, currency: rusty_money::iso::find(¤cy).unwrap_or(rusty_money::iso::PLN), } } } #[derive(Debug, Default)] pub struct Products { pub categories: Vec, pub product_ids: Vec, pub products: HashMap, } impl Products { pub fn update(&mut self, products: Vec) { let len = products.len(); self.categories = products .iter() .fold(HashSet::with_capacity(len), |mut set, p| { if let Some(category) = p.category.as_ref().cloned() { set.insert(category); } set }) .into_iter() .collect(); self.categories.sort_by(|a, b| a.name.cmp(&b.name)); self.product_ids = products.iter().map(|p| p.id).collect(); self.products = { let len = products.len(); products .into_iter() .fold(HashMap::with_capacity(len), |mut m, p| { m.insert(p.id, p); m }) }; } pub fn filter_product_ids(&self, filter: F) -> Vec where F: Fn(&model::api::Product) -> bool, { self.product_ids .iter() .filter_map(|id| self.products.get(id).filter(|&p| filter(p)).map(|p| p.id)) .collect() } }