@import "mixins/mixins";
@import "mixins/_button";
@import 'mixins/utils';
@import "common/var";

@mixin genTheme($backgroundColorWeight, $borderColorWeight, $fontColorWeight, $hoverColorWeight) {

  .el-radio-tag__orig-radio{
    &:focus-visible {
      & + .el-radio-tag--primary__inne {
        outline: 1px solid mix($--tag-primary-color, $--color-white, $fontColorWeight);
      }
      & + .el-radio-tag--info__inner {
        outline: 1px solid mix($--tag-info-color, $--color-white, $fontColorWeight);
      }
      & + .el-radio-tag--success__inner {
        outline: 1px solid mix($--tag-success-color, $--color-white, $fontColorWeight);
      }
      & + .el-radio-tag--warning__inner {
        outline: 1px solid mix($--tag-warning-color, $--color-white, $fontColorWeight);
      }
      & + .el-radio-tag--danger__inner {
        outline: 1px solid mix($--tag-danger-color, $--color-white, $fontColorWeight);
      }
    }
  }

  & .el-radio-tag--primary__inner{
    background-color: mix($--tag-primary-color, $--color-white, $backgroundColorWeight);
    border-color: mix($--tag-primary-color, $--color-white, $borderColorWeight);
    color: mix($--tag-primary-color, $--color-white, $fontColorWeight);
  }

  & .el-radio-tag--info__inner{
    background-color: mix($--color-info-light, $--color-white, $backgroundColorWeight);
    border-color: mix($--color-info-light, $--color-white, $borderColorWeight);
    color: mix($--tag-info-color, $--color-white, $fontColorWeight);
  }

  & .el-radio-tag--success__inner {
    background-color: mix($--tag-success-color, $--color-white, $backgroundColorWeight);
    border-color: mix($--tag-success-color, $--color-white, $borderColorWeight);
    color: mix($--tag-success-color, $--color-white, $fontColorWeight);
  }

  & .el-radio-tag--warning__inner {
    background-color: mix($--tag-warning-color, $--color-white, $backgroundColorWeight);
    border-color: mix($--tag-warning-color, $--color-white, $borderColorWeight);
    color: mix($--tag-warning-color, $--color-white, $fontColorWeight);
  }

  & .el-radio-tag--danger__inner {
    background-color: mix($--tag-danger-color, $--color-white, $backgroundColorWeight);
    border-color: mix($--tag-danger-color, $--color-white, $borderColorWeight);
    color: mix($--tag-danger-color, $--color-white, $fontColorWeight);
  }
}

@include b(radio-tag) {
  @include genTheme(15%, 20%, 100%, 100%);
  position: relative;
  display: inline-block;
  outline: none;

  @include e(inner) {
    display: inline-block;
    line-height: 1;
    font-weight: $--font-weight-primary;
    white-space: nowrap;
    vertical-align: middle;
    cursor: pointer;
    -webkit-appearance: none;
    text-align: center;
    box-sizing: border-box;
    outline: none;
    position: relative;
    transition: $--all-transition;
    border: 1px solid;
    box-sizing: border-box;
    @include utils-user-select(none);

    @include button-size(
      $--button-padding-vertical,
      $--button-padding-horizontal,
      $--button-font-size,
      $--tag-border-radius
    );

    & [class*='el-icon-'] {
      line-height: 0.8;

      & + span {
        margin-left: 5px;
      }
    }
  }

  & + & {
    margin-left: 10px;
  }

  &:hover {
    @include genTheme(20%, 40%, 100%, 100%);
  }

  @include e(orig-radio) {
    opacity: 0;
    outline: none;
    position: absolute;
    z-index: -1;

    &:focus-visible {
      & + .el-radio-tag__inner {
        outline-offset: -1px;
        outline: 1px solid $--color-primary;
      }
    }

    &:checked {
      & + .el-radio-tag__inner {
        color: $--radio-button-checked-font-color;
        background-color: $--radio-button-checked-background-color;
        border-color: $--radio-button-checked-border-color;
      }
    }

    &:disabled {
      & + .el-radio-tag__inner {
        color: $--button-disabled-font-color;
        cursor: not-allowed;
        background-image: none;
        background-color: $--button-disabled-background-color;
        border-color: $--button-disabled-border-color;
        box-shadow: none;
      }
      &:checked + .el-radio-tag__inner {
        background-color: $--radio-button-disabled-checked-fill;
        color: $--radio-button-checked-font-color;
      }
    }
  }

  @include when(disabled) {
    opacity: 0.5;
    @include genTheme(10%, 10%, 100%, 100%);
    @include when(active) {
      opacity: 1;
      @include genTheme(70%, 70%, 0%, 70%);
    }
    & .el-radio-tag__inner {
      cursor: not-allowed;
    }
  }

  @include when(plain) {
    @include genTheme(0%, 40%, 100%, 100%);
    &:not(.is-active, .is-disabled):hover {
      @include genTheme(10%, 60%, 100%, 100%);
    }
  }

  @include when(round) {
    @include e(inner) {
      border-radius: 20px;
    }
  }

  @include when(active) {
    @include genTheme(100%, 100%, 0%, 80%);
    &:not(.is-disabled):hover {
      @include genTheme(90%, 90%, 0%, 80%);
    }
  }

  @include m(medium) {
    & .el-radio-tag__inner {
      @include button-size($--button-medium-padding-vertical, $--button-medium-padding-horizontal, $--button-medium-font-size, 0);
    }
  }
  @include m(small) {
    & .el-radio-tag__inner {
      @include button-size($--button-small-padding-vertical, $--button-small-padding-horizontal, $--button-small-font-size, 0);
    }
  }
  @include m(mini) {
    & .el-radio-tag__inner {
      @include button-size($--button-mini-padding-vertical, $--button-mini-padding-horizontal, $--button-mini-font-size, 0);
    }
  }
}
