@import './theme/default';
@import './theme/font';

.zent-timeline {
  padding: 10px 0;
  position: relative;
  display: flex;

  &-dot {
    @include theme-color(background-color, stroke, 7);
    @include theme-color(border-color, primary, 4);
    width: 10px;
    height: 10px;
    border-radius: 50%;
    border-width: 2px;
    border-style: solid;
    box-sizing: border-box;
  }

  &-line {
    position: absolute;
  }

  &-legend {
    height: 20px;
    line-height: 20px;

    &-line {
      @include theme-color(background-color, primary, 4);
      position: relative;
      display: inline-block;
      width: 18px;
      height: 2px;
      vertical-align: middle;

      .zent-timeline-dot {
        position: absolute;
        top: 50%;
        right: 0;
        left: 0;
        margin: auto;
        transform: translateY(-50%);
      }
    }

    &-label {
      vertical-align: middle;
      font-size: $font-size-small;
      margin-left: 5px;
    }
  }

  &-item {
    position: relative;

    &-line {
      @include theme-color(background-color, stroke, 7);
      position: relative;

      .zent-timeline-dot {
        position: absolute;
        margin: auto;
      }
    }
  }

  &-horizontal {
    flex-direction: row;

    &.zent-timeline-dynamic {
      &::before {
        @include theme-color(background-color, stroke, 7);
        content: ' ';
        height: 2px;
        width: 100%;
        position: absolute;
        display: block;
        margin: 10px 0;
      }
    }

    .zent-timeline-item {
      position: relative;
      display: inline-block;
      vertical-align: top;

      &-hover {
        padding: 10px 0 40px;
      }

      &-line {
        height: 2px;
        width: 80px;
      }

      &-label {
        left: 0;
        top: 25px;
        position: absolute;
        bottom: 0;
      }

      .zent-timeline-dot {
        top: 50%;
        left: 0;
        transform: translateY(-50%);
      }
    }

    .zent-timeline-start {
      top: -25px;
      left: 0;
    }

    .zent-timeline-end {
      right: 0;
      top: 25px;
    }

    .zent-timeline-pad {
      display: inline-block;
    }
  }

  &-start {
    position: absolute;
  }

  &-end {
    position: absolute;
  }

  &-vertical {
    flex-direction: column;

    .zent-timeline-item {
      position: relative;
      display: block;
      line-height: 12px;

      &-hover {
        display: inline-block;
        vertical-align: top;
      }

      &-line {
        margin: 0 10px;
        width: 2px;
        vertical-align: top;
        height: 50px;

        .zent-timeline-dot {
          top: 0;
          left: -4px;
        }
      }

      &-label {
        display: inline-block;
        vertical-align: top;
      }
    }
  }
}

.zent-timeline-tip {
  @include theme-color(color, stroke, 9);
  background-color: rgba($color-black, 0.5);
  padding: 10px;
  border-radius: 5px;
  z-index: 5000;
  font-size: $font-size-small;
}
