use super::*;
pub(crate) mod flex_direction;
pub(crate) mod flex_wrap;
#[doc=include_str!("readme.md")]
#[derive(Debug, Clone)]
pub struct TailwindFlex {
kind: NumericValue,
}
impl Display for TailwindFlex {
fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
write!(f, "flex-{}", self.kind)
}
}
impl TailwindInstance for TailwindFlex {
fn attributes(&self, _: &TailwindBuilder) -> CssAttributes {
let flex = self.kind.get_properties(|f| f.to_string());
css_attributes! {
"flex" => flex
}
}
}
impl TailwindFlex {
pub fn adapt(pattern: &[&str], arbitrary: &TailwindArbitrary) -> Result<Box<dyn TailwindInstance>> {
let out = match pattern {
[] if arbitrary.is_none() => TailwindDisplay::from("flex").boxed(),
[] => TailwindFlex::parse_arbitrary(arbitrary)?.boxed(),
["row"] => TailwindFlexDirection::from("row").boxed(),
["row", "reverse"] => TailwindFlexDirection::from("row-reverse").boxed(),
["col"] => TailwindFlexDirection::from("column").boxed(),
["col", "reverse"] => TailwindFlexDirection::from("column-reverse").boxed(),
["direction", rest @ ..] => TailwindFlexDirection::parse(rest, arbitrary)?.boxed(),
["wrap", rest @ ..] => TailwindFlexWrap::parse(rest, arbitrary)?.boxed(),
["nowrap"] => TailwindFlexWrap::from("nowrap").boxed(),
_ => Self::parse(pattern, arbitrary)?.boxed(),
};
Ok(out)
}
pub fn parse(pattern: &[&str], arbitrary: &TailwindArbitrary) -> Result<TailwindFlex> {
let kind = NumericValue::positive_parser("flex", &Self::check_valid)(pattern, arbitrary)?;
Ok(TailwindFlex { kind })
}
pub fn parse_arbitrary(arbitrary: &TailwindArbitrary) -> Result<Self> {
NumericValue::parse_arbitrary(arbitrary).map(|kind| Self { kind })
}
pub fn check_valid(mode: &str) -> bool {
let set = BTreeSet::from_iter(vec!["auto", "inherit", "initial", "initial", "none", "revert", "unset"]);
set.contains(mode)
}
}