Skip to main content

Sass: How to create a 360 transform rotate class variation (from 0deg to 180deg)

This is how you can create a list of all the necessary css classes to rotate an html object with a class of loading-progress-[degree-rotation-from-0-180deg].

$i: 1;
@while $i <= 50 {

    $rotation: (180 * $i) / 50;
    $rotation_int: decimal-round($rotation);

    @keyframes loading-progress-#{$i}{
        0%{
            -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
        }
        100%{
            -webkit-transform: rotate(#{$rotation_int}deg);
            transform: rotate(#{$rotation_int}deg);
        }
      }

    .progress .progress-bar--#{$i}{
        font-size: $rotation_int;
        animation: loading-progress-#{$i} 0.4s linear forwards 1.8s;
    }

  $i: $i + 1;
}

The decimal-round function helps us to convert a float or decimal number to integer

@function decimal-round ($number, $digits: 0, $mode: round) {
    $n: 1;
    // $number must be a number
    @if type-of($number) != number {
        @warn '#{ $number } is not a number.';
        @return $number;
    }
    // $digits must be a unitless number
    @if type-of($digits) != number {
        @warn '#{ $digits } is not a number.';
        @return $number;
    } @else if not unitless($digits) {
        @warn '#{ $digits } has a unit.';
        @return $number;
    }
    @if $digits > 0 {
        @for $i from 1 through $digits {
            $n: $n * 10;
        }
    }
    @if $mode == round {
        @return round($number * $n) / $n;
    } @else if $mode == ceil {
        @return ceil($number * $n) / $n;
    } @else if $mode == floor {
        @return floor($number * $n) / $n;
    } @else {
        @warn '#{ $mode } is undefined keyword.';
        @return $number;
    }
}

 

coding

Latest Articles

Controlling ckeditor styling options with hook_editor_js_settings_alter admin_pixelthi… Thu, 05/16/2024 - 10:49 Controlling ckeditor styling options with hook_editor_js_settings_alter

Controlling ckeditor styling options with hook_editor_js_settings_alter

php hook hook_editor_js_settings_alter hook_field_widget_single_[WIDGET_TYPE]_form_alter
#1273 - Unknown collation: 'utf8mb4_0900_ai_ci' admin_pixelthi… Tue, 06/23/2020 - 13:21 #1273 - Unknown collation: 'utf8mb4_0900_ai_ci'

#1273 - Unknown collation: 'utf8mb4_0900_ai_ci'

utf8mb4
How to remove a primary tab from the admin menu in drupal 10 admin_pixelthi… Wed, 03/27/2024 - 17:39 How to remove a primary tab from the admin menu in drupal 10

How to remove a primary tab from the admin menu in drupal 10

hook