//
// 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 '../../config' as *;
@use '../../breakpoint' as *;
@use '../../motion' as *;
@use '../../spacing' as *;
@use '../../theme' as *;
@use '../../type' as *;
@use '../../utilities/component-reset';
@use '../../utilities/convert';
@use '../../utilities/focus-outline' as *;
@use '../select';

/// Unstable pagination styles
/// @access private
/// @group pagination
@mixin unstable_pagination {
  .#{$prefix}--unstable-pagination {
    @include component-reset.reset;
    @include type-style('body-compact-01');

    display: flex;
    align-items: center;
    justify-content: space-between;
    background-color: $layer;
    border-block-end: 1px solid transparent;
    border-block-start: 1px solid $border-subtle;
    container-name: pagination;
    container-type: inline-size;
    inline-size: 100%;
    min-block-size: convert.to-rem(40px);
  }

  .#{$prefix}--unstable-pagination__text {
    // 42rem = 'md' breakpoint width
    @container pagination (min-width: 42rem) {
      display: inline-block;
    }

    margin: 0 $spacing-05;
    color: $text-secondary;
  }

  .#{$prefix}--unstable-pagination__left,
  .#{$prefix}--unstable-pagination__right {
    display: flex;
    align-items: center;
    block-size: 100%;
  }

  .#{$prefix}--unstable-pagination__left {
    padding: 0 $spacing-05 0 0;
  }

  .#{$prefix}--unstable-pagination__left > .#{$prefix}--form-item,
  .#{$prefix}--unstable-pagination__right > .#{$prefix}--form-item {
    block-size: 100%;
  }

  .#{$prefix}--unstable-pagination__left
    .#{$prefix}--unstable-pagination__text {
    margin-inline-end: convert.to-rem(1px);
  }

  .#{$prefix}--unstable-pagination__right
    .#{$prefix}--unstable-pagination__text {
    margin-inline: convert.to-rem(1px) $spacing-05;
  }

  .#{$prefix}--unstable-pagination__button {
    @include component-reset.reset;

    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    margin: 0;
    background: none;
    block-size: convert.to-rem(40px);
    border-inline-start: 1px solid $border-subtle;
    color: $icon-primary;
    cursor: pointer;
    fill: $icon-primary;
    inline-size: convert.to-rem(40px);
    min-block-size: convert.to-rem(32px);
    transition:
      outline $duration-fast-02 motion(standard, productive),
      background-color $duration-fast-02 motion(standard, productive);
  }

  // Unset height/width set by icon-only button:
  .#{$prefix}--unstable-pagination__button .#{$prefix}--btn__icon {
    block-size: initial;
    inline-size: initial;
  }

  .#{$prefix}--unstable-pagination__button.#{$prefix}--btn--icon-only.#{$prefix}--tooltip__trigger:focus {
    @include focus-outline('outline');
  }

  .#{$prefix}--unstable-pagination__button:hover {
    background: $layer-hover;
    color: $icon-primary;
  }

  .#{$prefix}--unstable-pagination__button--no-index {
    cursor: not-allowed;
    fill: $icon-disabled;
  }

  .#{$prefix}--unstable-pagination__button.#{$prefix}--btn:disabled {
    border-color: $border-subtle;
    background: transparent;
  }

  .#{$prefix}--unstable-pagination__button:disabled:hover,
  .#{$prefix}--unstable-pagination__button--no-index:hover {
    background: transparent;
    cursor: not-allowed;
    fill: $icon-disabled;
  }

  .#{$prefix}--unstable-pagination__page-selector,
  .#{$prefix}--unstable-pagination__page-sizer {
    align-items: center;
    block-size: 100%;
  }

  .#{$prefix}--unstable-pagination__page-selector
    .#{$prefix}--select-input--inline__wrapper,
  .#{$prefix}--unstable-pagination__page-sizer
    .#{$prefix}--select-input--inline__wrapper {
    display: flex;
    block-size: 100%;
  }

  .#{$prefix}--unstable-pagination__page-selector .#{$prefix}--select-input,
  .#{$prefix}--unstable-pagination__page-sizer .#{$prefix}--select-input {
    @include type-style('body-short-01');

    padding: 0 2.25rem 0 $spacing-05;
    block-size: 100%;

    inline-size: auto;
    line-height: convert.to-rem(40px);

    min-inline-size: auto;
  }

  .#{$prefix}--unstable-pagination__page-selector
    .#{$prefix}--select-input:hover,
  .#{$prefix}--unstable-pagination__page-sizer .#{$prefix}--select-input:hover {
    background: $layer-hover;
  }

  .#{$prefix}--unstable-pagination__page-selector .#{$prefix}--select__arrow,
  .#{$prefix}--unstable-pagination__page-sizer .#{$prefix}--select__arrow {
    inset-block-start: 50%;
    transform: translateY(-50%);

    // 42rem = 'md' breakpoint width
    @container pagination (min-width: 42rem) {
      inset-inline-end: $spacing-05;
    }
  }

  .#{$prefix}--unstable-pagination__page-selector {
    border-inline-start: 1px solid $border-subtle;
  }

  .#{$prefix}--unstable-pagination__page-sizer {
    border-inline-end: 1px solid $border-subtle;
  }
}
