// NumberInput type="text" when allowDecimal is set.

@import "carbon-components/scss/globals/scss/vars";
@import "carbon-components/scss/globals/scss/css--reset";
@import "carbon-components/scss/globals/scss/helper-mixins";
@import "carbon-components/scss/globals/scss/typography";
@import "carbon-components/scss/globals/scss/vendor/@carbon/elements/scss/import-once/import-once";

/// @access private
/// @group number-input
@mixin number-input-text-type {
  .#{$prefix}--number input[type='text'] {
    @include type-style('code-01');
    @include focus-outline('reset');

    display: inline-flex;
    width: 100%;
    min-width: 9.375rem;
    height: to-rem(40px);
    box-sizing: border-box;
    padding-right: to-rem(128px);
    padding-left: $carbon--spacing-05;
    border: 0;
    border-bottom: to-rem(1px) solid $ui-04;

    // Firefox: Hide spinner (up and down buttons)
    -moz-appearance: textfield;
    appearance: textfield;
    background-color: $field-01;
    border-radius: 0;
    color: $text-01;
    font-family: carbon--font-family('mono');
    font-weight: 300;
    transition: background-color $duration--fast-01 motion(standard, productive),
      outline $duration--fast-01 motion(standard, productive);

    &:focus {
      @include focus-outline('outline');
    }

    &:disabled ~ .#{$prefix}--number__controls {
      cursor: not-allowed;
      pointer-events: none;
    }

    &:disabled ~ .#{$prefix}--number__controls svg {
      fill: $disabled;
    }

    // IE: Hide "clear-field" `x` button on input field
    &::-ms-clear {
      display: none;
    }

    // Safari: Hide number spinner
    &::-webkit-inner-spin-button {
      appearance: none;
    }
  }

  .#{$prefix}--number--lg.#{$prefix}--number input[type='text'] {
    padding-right: to-rem(144px);
  }

  .#{$prefix}--number--sm.#{$prefix}--number input[type='text'] {
    padding-right: to-rem(112px);
  }

  .#{$prefix}--number input[type='text']:disabled {
    border-bottom-color: transparent;
    background-color: $field-01;
    color: $disabled;
    cursor: not-allowed;
  }

  // Add top and bottom outlines to number controls when text input is focused
  .#{$prefix}--number
    input[type='text']:focus
    ~ .#{$prefix}--number__controls
    .#{$prefix}--number__control-btn {
    border-bottom-width: 0;

    &:hover {
      @include focus-outline('outline');

      border: 0;
    }
  }

  .#{$prefix}--number
    input[type='text'][data-invalid]
    ~ .#{$prefix}--number__controls
    .#{$prefix}--number__control-btn {
    border-bottom-width: 0;
  }

  // Add invalid outline to number controls only when invalid text input is not focused
  .#{$prefix}--number
    input[type='text'][data-invalid]:not(:focus)
    ~ .#{$prefix}--number__controls
    .#{$prefix}--number__control-btn:hover {
    @include focus-outline('invalid');
  }

  .#{$prefix}--number
    input[type='text']:focus
    ~ .#{$prefix}--number__controls
    .#{$prefix}--number__control-btn.up-icon::after {
    background-color: transparent;
  }

  .#{$prefix}--number
    input[type='text'][data-invalid]
    ~ .#{$prefix}--number__controls
    .#{$prefix}--number__control-btn.up-icon::after {
    background-color: $support-01;
  }

  .#{$prefix}--number
    input[type='text'][data-invalid]:focus
    ~ .#{$prefix}--number__controls
    .#{$prefix}--number__control-btn.up-icon::after,
  .#{$prefix}--number
    input[type='text'][data-invalid]
    ~ .#{$prefix}--number__controls
    .#{$prefix}--number__control-btn.up-icon:focus::after {
    background-color: $focus;
  }

  .#{$prefix}--number
    input[type='text']:disabled
    + .#{$prefix}--number__controls
    .#{$prefix}--number__rule-divider:first-of-type {
    background-color: transparent;
  }

  .#{$prefix}--number
    input[type='text']:disabled
    + .#{$prefix}--number__controls
    .#{$prefix}--number__rule-divider {
    background-color: $disabled;
  }

  .#{$prefix}--number--light input[type='text'] {
    background-color: $field-02;
  }

  .#{$prefix}--number--light input[type='text']:disabled {
    background-color: $field-02;
  }

  .#{$prefix}--number--lg input[type='text'] {
    height: to-rem(48px);
  }

  .#{$prefix}--number--sm input[type='text'] {
    height: to-rem(32px);
  }

  .#{$prefix}--number--nosteppers input[type='text'] {
    padding-right: to-rem(48px);
  }

  .#{$prefix}--number--readonly input[type='text'] {
    background: transparent;
  }
}

@include exports('number-input-text-type') {
  @include number-input-text-type;
}
