encre-css 0.20.1

A TailwindCSS-compatible utility-first CSS generation library written in Rust
Documentation
//! Transition and animation utilities
pub mod animation;
pub mod transition_delay;
pub mod transition_duration;
pub mod transition_property;
pub mod transition_timing_function;

#[cfg(test)]
mod tests {
    use crate::{generate, utils::testing::base_config};

    use pretty_assertions::assert_eq;

    #[test]
    fn animation() {
        assert_eq!(
            generate(["animate-none"], &base_config()),
            ".animate-none {
  -webkit-animation: none;
  animation: none;
}"
        );
        assert_eq!(
            generate(["animate-spin"], &base_config()),
            "@-webkit-keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

.animate-spin {
  -webkit-animation: spin 1s linear infinite;
  animation: spin 1s linear infinite;
}"
        );
        assert_eq!(
            generate(["animate-ping"], &base_config()),
            "@-webkit-keyframes ping {
  75%, 100% {
    transform: scale(2);
    opacity: 0;
  }
}

@keyframes ping {
  75%, 100% {
    transform: scale(2);
    opacity: 0;
  }
}

.animate-ping {
  -webkit-animation: ping 1s cubic-bezier(0, 0, 0.2, 1) infinite;
  animation: ping 1s cubic-bezier(0, 0, 0.2, 1) infinite;
}"
        );
        assert_eq!(
            generate(["animate-pulse"], &base_config()),
            "@-webkit-keyframes pulse {
  50% {
    opacity: .5;
  }
}

@keyframes pulse {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: .5;
  }
}

.animate-pulse {
  -webkit-animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
  animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}"
        );
        assert_eq!(
            generate(["animate-bounce"], &base_config()),
            "@-webkit-keyframes bounce {
  0%, 100% {
    transform: translateY(-25%);
    -webkit-animation-timing-function: cubic-bezier(0.8,0,1,1);
    animation-timing-function: cubic-bezier(0.8,0,1,1);
  }

  50% {
    transform: none;
    -webkit-animation-timing-function: cubic-bezier(0,0,0.2,1);
    animation-timing-function: cubic-bezier(0,0,0.2,1);
  }
}

@keyframes bounce {
  0%, 100% {
    transform: translateY(-25%);
    -webkit-animation-timing-function: cubic-bezier(0.8,0,1,1);
    animation-timing-function: cubic-bezier(0.8, 0, 1, 1);
  }
  50% {
    transform: translateY(0);
    -webkit-animation-timing-function: cubic-bezier(0,0,0.2,1);
    animation-timing-function: cubic-bezier(0, 0, 0.2, 1);
  }
}

.animate-bounce {
  -webkit-animation: bounce 1s infinite;
  animation: bounce 1s infinite;
}"
        );
    }

    #[test]
    fn transition_delay() {
        assert_eq!(
            generate(["delay-12"], &base_config()),
            ".delay-12 {
  transition-delay: 12ms;
}"
        );
        assert_eq!(
            generate(["delay-[4.3ms]"], &base_config()),
            r".delay-\[4\.3ms\] {
  transition-delay: 4.3ms;
}"
        );
    }

    #[test]
    fn transition_duration() {
        assert_eq!(
            generate(["duration-12"], &base_config()),
            ".duration-12 {
  transition-duration: 12ms;
}"
        );
        assert_eq!(
            generate(["duration-[4.3ms]"], &base_config()),
            r".duration-\[4\.3ms\] {
  transition-duration: 4.3ms;
}"
        );
    }

    #[test]
    fn transition_property() {
        assert_eq!(
            generate(["transition"], &base_config()),
            ".transition {
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}"
        );
        assert_eq!(
            generate(["transition-none"], &base_config()),
            ".transition-none {
  transition-property: none;
}"
        );
        assert_eq!(
            generate(["transition-all"], &base_config()),
            ".transition-all {
  transition-property: all;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}"
        );
        assert_eq!(
            generate(["transition-colors"], &base_config()),
            ".transition-colors {
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}"
        );
        assert_eq!(
            generate(["transition-opacity"], &base_config()),
            ".transition-opacity {
  transition-property: opacity;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}"
        );
        assert_eq!(
            generate(["transition-shadow"], &base_config()),
            ".transition-shadow {
  transition-property: box-shadow;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}"
        );
        assert_eq!(
            generate(["transition-transform"], &base_config()),
            ".transition-transform {
  transition-property: transform;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}"
        );
        assert_eq!(
            generate(["transition-[custom]"], &base_config()),
            r".transition-\[custom\] {
  transition-property: custom;
}"
        );
    }

    #[test]
    fn transition_timing_function() {
        assert_eq!(
            generate(["ease-linear"], &base_config()),
            ".ease-linear {
  transition-timing-function: linear;
}"
        );
        assert_eq!(
            generate(["ease-in"], &base_config()),
            ".ease-in {
  transition-timing-function: cubic-bezier(0.4, 0, 1, 1);
}"
        );
        assert_eq!(
            generate(["ease-out"], &base_config()),
            ".ease-out {
  transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
}"
        );
        assert_eq!(
            generate(["ease-in-out"], &base_config()),
            ".ease-in-out {
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}"
        );
        assert_eq!(
            generate(["ease-[steps(4,_jump-end)]"], &base_config()),
            r".ease-\[steps\(4\,_jump-end\)\] {
  transition-timing-function: steps(4, jump-end);
}"
        );
    }
}