/*
 * SPDX-FileCopyrightText: 2023 Siemens AG
 *
 * SPDX-License-Identifier: MIT
 *
 * This source code is licensed under the MIT license found in the
 * LICENSE file in the root directory of this source tree.
 */

@use 'common-variables' as vars;
@use 'mixins/hover';
@use 'mixins/text-truncation';
@use 'legacy/mixins/fonts';

@mixin from-control-invalid {
  color: $form-feedback-invalid-color;
}

.ix-form-control,
.ix-form-control-plaintext {
  color: var(--theme-input--color);
  border-radius: var(--theme-input--border-radius);
  height: vars.$default-control-height;
  min-height: vars.$default-control-height;
  min-width: vars.$input-min-width;
  background-color: var(--theme-input--background);
  border: solid 1px var(--theme-input--border-color);
  box-shadow: var(--theme-input--box-shadow);
  padding-inline-start: vars.$input-padding-x;
  padding-inline-end: vars.$input-padding-x;

  @include fonts.text-default();
  @include text-truncation.ellipsis;

  &::placeholder {
    color: var(--theme-input-hint--color);
  }

  &:not(:read-only):not([readonly]):not([readOnly]):not(.readonly) {
    @include hover.hover {
      background-color: var(--theme-input--background--hover);
      border-color: var(--theme-input--border-color--hover);
      cursor: auto;
    }

    @include hover.focus-visible {
      background-color: var(--theme-input--background--focus);
      border-color: var(--theme-input--border-color--focus);
      outline-offset: var(--theme-input--focus--outline-offset);
      box-shadow: var(--theme-input--box-shadow);
      outline: 1px solid var(--theme-color-focus-bdr);
    }
  }
}

.ix-form-control:focus-visible {
  color: var(--theme-input--color);
}

.ix-form-control[type='number'] {
  &::-webkit-inner-spin-button {
    margin-right: -2px;
    margin-left: 2px;
    display: none;
  }

  text-align: right;
}

.ix-form-control.readonly,
.ix-form-control[readonly] {
  background: transparent !important;
  border-block-start: none !important;
  border-inline-start: none !important;
  border-inline-end: none !important;
  border-radius: 0rem;
}

.ix-form-control:read-only,
.ix-form-control[readonly],
.ix-form-control[readOnly],
.ix-form-control.readonly {
  box-shadow: none !important;
  outline: none !important;
  border-color: var(--theme-input--border-color);
  cursor: default !important;

  &::placeholder {
    color: transparent;
  }
}

.ix-form-control:disabled,
.ix-form-control.disabled {
  background: transparent !important;
  border-block-start: none !important;
  border-inline-start: none !important;
  border-inline-end: none !important;
  border-radius: 0rem;
  color: var(--theme-color-weak-text);

  border-color: var(--theme-input--border-color-bottom--disabled);

  &::placeholder {
    color: transparent;
  }
}

.ix-form-control-plaintext {
  outline: 0;
}

.form-group {
  position: relative;
}

.input-wrapper {
  display: flex;
  position: relative;
  align-items: center;
  flex-wrap: nowrap;

  > .glyph {
    display: block;
    position: absolute;
    margin-inline-start: 0.312rem;
    color: var(--theme-color-std-text);
  }

  > input {
    padding-inline-start: 2.2rem;
  }
}

select.ix-form-control {
  padding: 0 0.312rem;
}

textarea.ix-form-control {
  padding: 0.375rem vars.$small-space;
}

input.ix-form-control {
  &.disabled,
  &:disabled {
    color: var(--theme-input--color--disabled);
  }

  &:read-only,
  &.readonly {
    cursor: default;
  }
}
