/**
 * @license EUPL-1.2+
 * Copyright Gemeente Amsterdam
 */

@use "../../common/text-rendering" as *;

@mixin reset-input {
  -webkit-appearance: none; // Reset appearance for Safari < 15.4
  appearance: none; // Reset native appearance, this causes issues on iOS and Android devices
  border: none;
  border-radius: 0; // Reset rounded borders on iOS devices
  inline-size: auto; // Reset inline size of 10em set by Android devices
  margin-block: 0;
}

.ams-time-input {
  background-color: var(--ams-time-input-background-color);
  box-shadow: var(--ams-time-input-box-shadow);
  box-sizing: border-box;
  color: var(--ams-time-input-color);
  font-family: var(--ams-time-input-font-family);
  font-size: var(--ams-time-input-font-size);
  font-weight: var(--ams-time-input-font-weight);
  line-height: var(--ams-time-input-line-height);

  // Set min block size for iOS, otherwise an empty box is a lot smaller than a filled one.
  min-block-size: calc(
    (var(--ams-time-input-font-size) * var(--ams-time-input-line-height)) + 2 * var(--ams-time-input-padding-block)
  );

  // Set min inline size for iOS, so the size is closer to the filled in size.
  min-inline-size: calc(4ch + (2 * var(--ams-time-input-padding-inline)));
  outline-offset: var(--ams-time-input-outline-offset);
  padding-block: var(--ams-time-input-padding-block);
  padding-inline: var(--ams-time-input-padding-inline);
  touch-action: manipulation;

  @include text-rendering;
  @include reset-input;

  &:hover {
    box-shadow: var(--ams-time-input-hover-box-shadow);
  }
}

// This changes the default calendar icon on Chromium browsers only
.ams-time-input::-webkit-calendar-picker-indicator {
  appearance: none;
  background-image: var(--ams-time-input-calender-picker-indicator-background-image);
  cursor: var(--ams-time-input-calender-picker-indicator-cursor);
}

.ams-time-input:hover::-webkit-calendar-picker-indicator {
  background-image: var(--ams-time-input-hover-calender-picker-indicator-background-image);
}

.ams-time-input:disabled {
  background-color: var(--ams-time-input-disabled-background-color);
  box-shadow: var(--ams-time-input-disabled-box-shadow);
  color: var(--ams-time-input-disabled-color);
  cursor: var(--ams-time-input-disabled-cursor);
}

.ams-time-input:disabled::-webkit-calendar-picker-indicator {
  background-image: var(--ams-time-input-disabled-calender-picker-indicator-background-image);
  visibility: visible;
}

.ams-time-input:invalid,
.ams-time-input[aria-invalid="true"] {
  box-shadow: var(--ams-time-input-invalid-box-shadow);

  &:hover {
    box-shadow: var(--ams-time-input-invalid-hover-box-shadow);
  }
}
