@import '../../scss/variables/colors';

$base-class: 'multiselect';

.#{$base-class} {
  position: relative;
  width: inherit;
  color: $font-primary-color;
  font-size: 15px;
  line-height: 1.2;

  &-head {
    position: relative;
    border: 1px solid $border-primary-color;
    border-radius: 4px;
    background-color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    outline: 0;
    transition: border 0.15s ease-in-out;

    &:hover {
      border-color: $field-hover-border-color;
      transition: border 0.15s ease-in-out;
    }

    &--focused {
      border-color: $primary-color;
      transition: border 0.15s ease-in-out;

      &:hover {
        border-color: $primary-color;
        transition: border 0.15s ease-in-out;
      }
    }

    &--disabled {
      opacity: 0.4;
      pointer-events: none;
      cursor: not-allowed;
    }
  }

  &-head__clear {
    opacity: 0;
    visibility: hidden;
    display: flex;
    transition: all 0.15s ease-in-out;

    &--visible {
      opacity: 1;
      visibility: visible;
      transition: all 0.15s ease-in-out;
    }
  }

  &-head__search {
    display: block;
    margin: 2px 3px;
    color: $font-primary-color;
    border: none;
    background-color: transparent;
    box-sizing: border-box;
    outline: none;
    line-height: 1.2;

    ::placeholder,
    ::-webkit-input-placeholder,
    ::-moz-placeholder,
    :-moz-placeholder,
    :-ms-input-placeholder,
    ::-ms-input-placeholder {
      opacity: 0.4;
      color: $font-primary-color;
    }

    &:focus,
    &:active,
    &:hover {
      outline: none;

      .#{$base-class}-head {
        border: 1px solid $primary-color;
      }
    }

    &--expanded {
      width: auto;
    }
  }

  &-body {
    position: absolute;
    top: 100%;
    width: 100%;
    margin-top: 4px;
    background-color: #fff;
    box-sizing: border-box;
    border-radius: 4px;
    box-shadow: 0 2px 20px 0 rgba(0, 0, 0, 0.2);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-10%);
    transform-origin: top center;
    transition: all 0.15s ease-in-out;
    overflow: hidden;
    z-index: 100000;
    padding: 4px 0 8px 0;

    &--visible {
      opacity: 1;
      visibility: visible;
      pointer-events: auto;
      transform: translateY(0);
      transition: all 0.15s ease-in-out;
    }

    &__list {
      max-height: 224px;
      margin: 0;
      padding: 0;
      overflow-x: hidden;
      overflow-y: auto;
    }

    &__item {
      position: relative;
      list-style: none;
      cursor: pointer;
      display: flex;
      padding: 9px 16px;
      align-items: center;

      &-content {
        overflow: hidden;
        white-space: nowrap;
        text-overflow: ellipsis;
        max-width: calc(100% - 20px);
        width: 100%;
      }

      &--selected {
        color: $primary-color;

        .#{$base-class}-body__checkmark {
          opacity: 1;
          visibility: visible;
          transition: all 0.15s ease-in-out;
        }
      }

      &--focused {
        background-color: $hover-background-color;
      }

      &--toggle {
        border-bottom: 1px solid $divider-color;
      }
    }
  }

  &-body__checkmark {
    opacity: 0;
    visibility: hidden;
    transition: all 0.15s ease-in-out;
    fill: $primary-color;
    margin-left: auto;
    padding-left: 5px;
  }

  &-head__items {
    height: 100%;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    overflow-y: auto;
    padding: 2px 2px;
    flex: 1;
    opacity: 1;
    visibility: visible;
  }

  &-head__items-empty {
    padding: 5px 12px;
    height: 100%;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    overflow-y: auto;
    flex: 1;
    opacity: 1;
    visibility: visible;
  }

  &__placeholder {
    margin: 3px 3px;
    opacity: 0.4;
    color: $font-primary-color;
  }

  &-head__item {
    background-color: #59699e;
    min-width: auto;
    color: #fff;
    position: relative;
    margin: 2px 3px;
    border-radius: 5px;
    padding: 2px 6px 4px 6px;
    line-height: normal;
    margin: 3px 3px 2px 3px;
    cursor: default;
    overflow: hidden;
    display: flex;
    align-items: center;

    &-content {
      width: calc(100% - 22px);
      flex-grow: 1;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }

    &-remove-icon {
      opacity: 0.5;
      margin-right: 8px;
      cursor: pointer;
    }
  }

  &__dropdown-icon {
    align-self: flex-start;
    margin-top: 4px;
  }

  &--error {
    .#{$base-class}-head {
      border-color: $error-color;
    }
  }
}
