@use "./common/mixins.scss" as *;

@include b(popover) {
  position: relative;
  display: inline-block;

  @include e(content) {
    position: absolute;
    background: white;
    color: #333;
    padding: 12px;
    border-radius: 4px;
    font-size: 14px;
    z-index: 1000;
    min-width: 150px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.1);
    border: 1px solid #ebeef5;

    &::before,
    &::after {
      content: "";
      position: absolute;
      width: 0;
      height: 0;
    }

    &::before {
      border: 6px solid transparent;
      z-index: 1;
    }

    &::after {
      border: 5px solid transparent;
      z-index: 2;
    }
  }

  @include e(title) {
    padding-bottom: 8px;
    margin-bottom: 8px;
    font-size: 16px;
    font-weight: 500;
    border-bottom: 1px solid #ebeef5;
  }

  @include m(content, top) {
    bottom: calc(100% + 10px);
    left: 50%;
    transform: translateX(-50%);

    &::before {
      bottom: -12px;
      left: 50%;
      transform: translateX(-50%);
      border-top-color: #ebeef5;
    }

    &::after {
      bottom: -10px;
      left: 50%;
      transform: translateX(-50%);
      border-top-color: white;
    }
  }

  @include m(content, bottom) {
    top: calc(100% + 10px);
    left: 50%;
    transform: translateX(-50%);

    &::before {
      top: -12px;
      left: 50%;
      transform: translateX(-50%);
      border-bottom-color: #ebeef5;
    }

    &::after {
      top: -10px;
      left: 50%;
      transform: translateX(-50%);
      border-bottom-color: white;
    }
  }

  @include m(content, left) {
    right: calc(100% + 10px);
    top: 50%;
    transform: translateY(-50%);

    &::before {
      right: -12px;
      top: 50%;
      transform: translateY(-50%);
      border-left-color: #ebeef5;
    }

    &::after {
      right: -10px;
      top: 50%;
      transform: translateY(-50%);
      border-left-color: white;
    }
  }

  @include m(content, right) {
    left: calc(100% + 10px);
    top: 50%;
    transform: translateY(-50%);

    &::before {
      left: -12px;
      top: 50%;
      transform: translateY(-50%);
      border-right-color: #ebeef5;
    }

    &::after {
      left: -10px;
      top: 50%;
      transform: translateY(-50%);
      border-right-color: white;
    }
  }
}

// 过渡动画
.x-popover-enter-active,
.x-popover-leave-active {
  transition: opacity 0.2s, transform 0.2s;
}

.x-popover-enter-from,
.x-popover-leave-to {
  opacity: 0;
  transform: scale(0.8);
}
