//
// Copyright IBM Corp. 2016, 2023
//
// This source code is licensed under the Apache-2.0 license found in the
// LICENSE file in the root directory of this source tree.
//

@use 'mixins' as *;
@use 'tokens' as *;
@use '../../breakpoint' as *;
@use '../../colors' as *;
@use '../../config' as *;
@use '../../feature-flags';
@use '../../motion' as *;
@use '../../spacing' as *;
@use '../../theme' as *;
@use '../../themes' as *;
@use '../../type' as *;
@use '../../utilities/convert';
@use '../../utilities/high-contrast-mode' as *;
@use '../../utilities/focus-outline' as *;
@use './tokens' as *;

/// Toast notification styles
/// @access public
/// @group notification
@mixin toast-notification {
  .#{$prefix}--toast-notification {
    @include reset;

    display: flex;
    block-size: auto;
    box-shadow: 0 2px 6px 0 rgba(0, 0, 0, 0.2);
    color: $text-inverse;
    inline-size: convert.to-rem(288px);
    padding-inline-start: convert.to-rem(13px);

    @include breakpoint(max) {
      inline-size: convert.to-rem(352px);
    }
  }

  .#{$prefix}--toast-notification:not(
      .#{$prefix}--toast-notification--low-contrast
    )
    a {
    color: $link-inverse;
  }

  .#{$prefix}--toast-notification a {
    text-decoration: none;
  }

  .#{$prefix}--toast-notification a:hover {
    text-decoration: underline;
  }

  .#{$prefix}--toast-notification a:focus {
    outline: 1px solid $link-inverse;
  }

  .#{$prefix}--toast-notification.#{$prefix}--toast-notification--low-contrast
    a:focus {
    @include focus-outline;
  }

  .#{$prefix}--toast-notification--low-contrast {
    color: $text-primary;
  }

  .#{$prefix}--toast-notification--error {
    @include notification--experimental(
      $support-error-inverse,
      $background-inverse
    );
  }

  .#{$prefix}--toast-notification--low-contrast.#{$prefix}--toast-notification--error {
    @include notification--experimental(
      $support-error,
      $notification-background-error
    );
  }

  .#{$prefix}--toast-notification--success {
    @include notification--experimental(
      $support-success-inverse,
      $background-inverse
    );
  }

  .#{$prefix}--toast-notification--low-contrast.#{$prefix}--toast-notification--success {
    @include notification--experimental(
      $support-success,
      $notification-background-success
    );
  }

  .#{$prefix}--toast-notification--info,
  .#{$prefix}--toast-notification--info-square {
    @include notification--experimental(
      $support-info-inverse,
      $background-inverse
    );
  }

  .#{$prefix}--toast-notification--low-contrast.#{$prefix}--toast-notification--info,
  .#{$prefix}--toast-notification--low-contrast.#{$prefix}--toast-notification--info-square {
    @include notification--experimental(
      $support-info,
      $notification-background-info
    );
  }

  .#{$prefix}--toast-notification--warning,
  .#{$prefix}--toast-notification--warning-alt {
    @include notification--experimental(
      $support-warning-inverse,
      $background-inverse
    );
  }

  .#{$prefix}--toast-notification--low-contrast.#{$prefix}--toast-notification--warning,
  .#{$prefix}--toast-notification--low-contrast.#{$prefix}--toast-notification--warning-alt {
    @include notification--experimental(
      $support-warning,
      $notification-background-warning
    );
  }

  .#{$prefix}--toast-notification--warning
    .#{$prefix}--toast-notification__icon
    path[opacity='0'],
  .#{$prefix}--toast-notification--warning-alt
    .#{$prefix}--toast-notification__icon
    path:first-of-type {
    fill: $black-100;
    opacity: 1;
  }

  .#{$prefix}--toast-notification__icon {
    flex-shrink: 0;
    margin-block-start: $spacing-05;
    margin-inline-end: $spacing-05;
  }

  .#{$prefix}--toast-notification__details {
    margin-block-end: $spacing-05;
    margin-inline-end: $spacing-05;
  }

  .#{$prefix}--toast-notification__close-button {
    @include focus-outline('reset');

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: none;
    background-color: transparent;
    block-size: convert.to-rem(48px);
    cursor: pointer;
    inline-size: convert.to-rem(48px);
    margin-inline-start: auto;
    min-block-size: convert.to-rem(48px);
    min-inline-size: convert.to-rem(48px);
    transition:
      outline $transition-base,
      background-color $transition-base;

    &:focus {
      outline: 2px solid $focus-inverse;
      outline-offset: -2px;
    }

    .#{$prefix}--toast-notification__close-icon {
      fill: $icon-inverse;
    }
  }

  .#{$prefix}--toast-notification--low-contrast
    .#{$prefix}--toast-notification__close-button:focus {
    @include focus-outline('outline');
  }

  .#{$prefix}--toast-notification--low-contrast
    .#{$prefix}--toast-notification__close-button
    .#{$prefix}--toast-notification__close-icon {
    fill: $icon-primary;
  }

  .#{$prefix}--toast-notification__title {
    @include type-style('heading-compact-01');

    font-weight: 600;
    margin-block-start: $spacing-05;
    word-break: break-word;
  }

  .#{$prefix}--toast-notification__subtitle {
    @include type-style('body-compact-01');

    color: $text-inverse;
    margin-block: 0 $spacing-05;
    word-break: break-word;
  }

  .#{$prefix}--toast-notification--low-contrast
    .#{$prefix}--toast-notification__subtitle {
    color: $text-primary;
  }

  .#{$prefix}--toast-notification__caption {
    @include type-style('body-compact-01');

    color: $text-inverse;
    padding-block-start: $spacing-03;
  }

  .#{$prefix}--toast-notification--low-contrast
    .#{$prefix}--toast-notification__caption {
    color: $text-primary;
  }

  // Windows HCM fix

  .#{$prefix}--toast-notification {
    @include high-contrast-mode('outline');
  }
  .#{$prefix}--toast-notification__close-button:focus {
    @include high-contrast-mode('focus');
  }
}
