tailwind_css/modules/transforms/skew/
mod.rs

1use super::*;
2
3#[doc=include_str!("readme.md")]
4#[derive(Clone, Debug)]
5pub struct TailwindSkew {
6    axis: AxisXY,
7    kind: UnitValue,
8}
9
10impl Display for TailwindSkew {
11    fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
12        self.kind.write_negative(f)?;
13        self.axis.write_xyn(f, "skew-", &self.kind)
14    }
15}
16
17impl TailwindInstance for TailwindSkew {
18    fn attributes(&self, _: &TailwindBuilder) -> CssAttributes {
19        let deg = self.kind.get_properties(|n| format!("{}deg", n));
20        let transform = match self.axis {
21            AxisXY::X => format!("skewX({})", deg),
22            AxisXY::Y => format!("skewY({})", deg),
23            AxisXY::N => format!("skew({})", deg),
24        };
25        css_attributes! {
26            "transform" => transform,
27        }
28    }
29}
30
31impl TailwindSkew {
32    // <https://tailwindcss.com/docs/skew>
33    pub fn parse(pattern: &[&str], arbitrary: &TailwindArbitrary, negative: Negative) -> Result<Self> {
34        let (axis, rest) = AxisXY::split_xyn(pattern);
35        let kind = UnitValue::negative_parser("skew", |_| false, false, false, false)(rest, arbitrary, negative)?;
36        Ok(Self { kind, axis })
37    }
38}