@use 'sass:map';
@use '../../base' as *;

/// @deprecated Use the `css-vars` mixin instead.
/// @see {mixin} css-vars
/// @param {Map} $theme - The theme used to style the component.
@mixin banner($theme) {
    @include css-vars($theme);
    $variant: map.get($theme, '_meta', 'theme');

    %igx-banner-host {
        igx-expansion-panel-body {
            padding: 0;
        }
    }

    %igx-banner__actions,
    %igx-banner__actions > igx-banner-actions,
    %igx-banner__illustration,
    %igx-banner__message {
        display: flex;
    }

    %igx-banner__illustration,
    %igx-banner__message {
        align-items: center;
    }

    %igx-banner {
        @include sizable();
        --component-size: var(--ig-size, var(--ig-size-large));

        display: flex;
        justify-content: flex-end;
        flex-wrap: wrap;
        gap: rem(8px);
        padding: pad-block(rem(16px)) pad-inline(rem(8px));
        min-width: rem(320px);
        background: var-get($theme, 'banner-background');
        box-shadow: inset 0 rem(-1px) 0 0 var-get($theme, 'banner-border-color');
        border-radius: var-get($theme, 'border-radius');

        @if $variant == 'indigo' {
            box-shadow: inset 0 0 0 rem(1px) var-get($theme, 'banner-border-color');
            padding: pad(rem(16px));
        }

        igc-icon,
        igx-icon,
        igc-button,
        [igxButton] {
            --component-size: var(--ig-size, var(--ig-size-large));

            @if $variant == 'indigo' {
                --component-size: var(--ig-size, var(--ig-size-medium));
            }
        }
    }

    %igx-banner__illustration {
        justify-content: center;
        color: var-get($theme, 'banner-illustration-color');
    }

    %igx-banner__text {
        color: var-get($theme, 'banner-message-color');
        flex: 1 0 0%;

        > * {
            margin-block-start: 0 !important;
        }
    }

    %igx-banner__message {
        min-width: rem(150px);
        flex: 1 0 0%;
        gap: rem(16px);

        @if $variant == 'indigo' {
            gap: rem(8px);
        } @else {
            padding: 0 pad-inline(rem(8px));
        }
    }

    %igx-banner__actions,
    %igx-banner__actions > igx-banner-actions {
        flex-wrap: wrap;
        align-self: flex-end;
        gap: rem(8px);

        > a {
            display: inline-flex;
            align-items: center;
        }
    }
}

/// Adds typography styles for the igx-banner component.
/// Uses the 'body-2' category from the typographic scale.
/// @group typography
/// @param {Map} $categories [(message: 'body-2')] - The categories from the typographic scale used for type styles.
@mixin banner-typography($categories: (
    message: 'body-2')
) {
    $message: map.get($categories, 'message');

    %igx-banner__text {
        @include type-style($message) {
            margin-block-start: 0;
            margin-block-end: 0;
        }
    }
}
