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

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

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

  & .el-checkbox-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-checkbox-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-checkbox-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-checkbox-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-checkbox-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(checkbox-tag) {
  @include genTheme(15%, 20%, 100%, 100%);
  position: relative;
  display: inline-block;
  line-height: 1;
  vertical-align: bottom;
  @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(original) {
    opacity: 0;
    outline: none;
    position: absolute;
    margin: 0;
    z-index: -1;
    &:focus-visible {
      & + .el-checkbox-tag__inner {
        outline-offset: 1px;
        outline: 1px solid $--color-primary;
      }
    }
  }

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

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

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

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

  @include m(medium) {
    .el-checkbox-tag__inner {
      @include button-size(
        $--button-medium-padding-vertical,
        $--button-medium-padding-horizontal,
        $--button-medium-font-size,
        $--tag-border-radius
      );
    }
  }
  @include m(small) {
    .el-checkbox-tag__inner {
      @include button-size(
        $--button-small-padding-vertical,
        $--button-small-padding-horizontal,
        $--button-small-font-size,
        $--tag-border-small-radius
      );
    }
  }
  @include m(mini) {
    .el-checkbox-tag__inner {
      @include button-size(
        $--button-mini-padding-vertical,
        $--button-mini-padding-horizontal,
        $--button-mini-font-size,
        $--tag-border-small-radius
      );
    }
  }
}