/*
 * Copyright (c) 2016-2025 Broadcom. All Rights Reserved.
 * The term "Broadcom" refers to Broadcom Inc. and/or its subsidiaries.
 * This software is released under MIT license.
 * The full license information can be found in LICENSE in the root directory of this project.
 */

@use 'sass:map';
@use '../../../utils/variables/variables';
@use 'breakpoint';
@use 'grid';

@mixin clr-make-grid-columns(
  $columns: variables.$clr-grid-columns,
  $gutter: variables.$clr-grid-column-padding,
  $breakpoints: variables.$clr-grid-breakpoints
) {
  // Common properties for all breakpoints
  %clr-grid-column {
    width: 100%;
    min-height: variables.$clr_baselineRem_1px; // Prevent columns from collapsing when empty
    padding-right: $gutter;
    padding-left: $gutter;
  }

  @each $breakpoint in map.keys($breakpoints) {
    $infix: breakpoint.clr-breakpoint-infix($breakpoint, $breakpoints);

    // Allow columns to stretch full width below their breakpoints
    @for $i from 1 through $columns {
      .clr-col#{$infix}-#{$i} {
        @extend %clr-grid-column;
      }
    }

    .clr-col#{$infix},
    .clr-col#{$infix}-auto {
      @extend %clr-grid-column;
    }

    @include breakpoint.clr-media-breakpoint-up($breakpoint, $breakpoints) {
      // Provide basic `.clr-col-{bp}` classes for equal-width flexbox columns
      .clr-col#{$infix} {
        flex-basis: 0;
        flex-grow: 1;
        max-width: 100%;
      }

      .clr-col#{$infix}-auto {
        flex: 0 0 auto;
        width: auto;
        max-width: none; // Reset earlier grid tiers
      }

      @for $i from 1 through $columns {
        .clr-col#{$infix}-#{$i} {
          @include grid.clr-make-col($i, $columns);
        }
      }

      .clr-order#{$infix}-first {
        order: -1;
      }

      .clr-order#{$infix}-last {
        order: $columns + 1;
      }

      @for $i from 0 through $columns {
        .clr-order#{$infix}-#{$i} {
          order: $i;
        }
      }

      // `$columns - 1` because offsetting by the width of an entire row isn't possible
      @for $i from 0 through ($columns - 1) {
        @if not($infix == '' and $i == 0) {
          /* stylelint-disable */
          // Avoid emitting useless .offset-0
          .clr-offset#{$infix}-#{$i} {
            @include grid.clr-make-col-offset($i, $columns);
          }
          /* stylelint-enable */
        }
      }
    }
  }
}
