@import 'vars';

// cropper
// =================================================
// Cropper
// =========================
.cropper-container {
  position: relative;
  font-size: 0;
  line-height: 0;
  user-select: none;
  direction: ltr !important; // Ignore global rtl

  img {
    // Avoid margin top issue (Occur only when margin-top <= -height)
    display: block;
    width: 100%;
    min-width: 0 !important;
    max-width: none !important;
    height: 100%;
    min-height: 0 !important;
    max-height: none !important;

    // https://developer.mozilla.org/en-US/docs/Web/CSS/image-orientation
    image-orientation: 0deg !important;
  }
}

.cropper-wrap-box, .cropper-canvas, .cropper-drag-box, .cropper-crop-box, .cropper-modal {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

.cropper-wrap-box {
  overflow: hidden;
}

.cropper-drag-box {
  background-color: #fff;
  opacity: 0;
}

.cropper-modal {
  background-color: #000;
  opacity: .5;
}

.cropper-view-box {
  display: block;
  width: 100%;
  height: 100%;
  overflow: hidden;
  outline: 1px solid $color-primary-600;
  outline-color: rgba($color-primary-600, .75);
}

.cropper-dashed {
  position: absolute;
  display: block;
  border: 0 dashed #eee;
  opacity: .5;

  &.dashed-h {
    top: percentage(1 / 3);
    left: 0;
    width: 100%;
    height: percentage(1 / 3);
    border-top-width: 1px;
    border-bottom-width: 1px;
  }

  &.dashed-v {
    top: 0;
    left: percentage(1 / 3);
    width: percentage(1 / 3);
    height: 100%;
    border-right-width: 1px;
    border-left-width: 1px;
  }
}

.cropper-center {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: 0;
  height: 0;
  opacity: .75;

  &:before, &:after {
    position: absolute;
    display: block;
    content: " ";
    background-color: #eee;
  }

  &:before {
    top: 0;
    left: -3px;
    width: 7px;
    height: 1px;
  }

  &:after {
    top: -3px;
    left: 0;
    width: 1px;
    height: 7px;
  }
}

.cropper-face, .cropper-line, .cropper-point {
  position: absolute;
  display: block;
  width: 100%;
  height: 100%;
  opacity: .1;
}

.cropper-face {
  top: 0;
  left: 0;
  background-color: #fff;
}

.cropper-line {
  background-color: $color-primary-600;

  &.line-e {
    top: 0;
    right: -3px;
    width: 5px;
    cursor: e-resize;
  }

  &.line-n {
    top: -3px;
    left: 0;
    height: 5px;
    cursor: n-resize;
  }

  &.line-w {
    top: 0;
    left: -3px;
    width: 5px;
    cursor: w-resize;
  }

  &.line-s {
    bottom: -3px;
    left: 0;
    height: 5px;
    cursor: s-resize;
  }
}

.cropper-point {

  @include media-breakpoint-up(sm) {
    &.point-se {
      width: 15px;
      height: 15px;
    }
  }

  @include media-breakpoint-up(md) {
    &.point-se {
      width: 10px;
      height: 10px;
    }
  }

  @include media-breakpoint-up(lg) {
    &.point-se {
      width: 5px;
      height: 5px;
      opacity: .75;
    }
  }
  width: 5px;
  height: 5px;
  background-color: $color-primary-600;
  opacity: .75;

  &.point-e {
    top: 50%;
    right: -3px;
    margin-top: -3px;
    cursor: e-resize;
  }

  &.point-n {
    top: -3px;
    left: 50%;
    margin-left: -3px;
    cursor: n-resize;
  }

  &.point-w {
    top: 50%;
    left: -3px;
    margin-top: -3px;
    cursor: w-resize;
  }

  &.point-s {
    bottom: -3px;
    left: 50%;
    margin-left: -3px;
    cursor: s-resize;
  }

  &.point-ne {
    top: -3px;
    right: -3px;
    cursor: ne-resize;
  }

  &.point-nw {
    top: -3px;
    left: -3px;
    cursor: nw-resize;
  }

  &.point-sw {
    bottom: -3px;
    left: -3px;
    cursor: sw-resize;
  }

  &.point-se {
    right: -3px;
    bottom: -3px;
    width: 20px;
    height: 20px;
    cursor: se-resize;
    opacity: 1;
  }

  &.point-se:before {
    position: absolute;
    right: -50%;
    bottom: -50%;
    display: block;
    width: 200%;
    height: 200%;
    content: " ";
    background-color: $color-primary-600;
    opacity: 0;
  }
}

// Visual
// -------------------------

.cropper-invisible {
  opacity: 0;
}

.cropper-bg {
  background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQAQMAAAAlPW0iAAAAA3NCSVQICAjb4U/gAAAABlBMVEXMzMz////TjRV2AAAACXBIWXMAAArrAAAK6wGCiw1aAAAAHHRFWHRTb2Z0d2FyZQBBZG9iZSBGaXJld29ya3MgQ1M26LyyjAAAABFJREFUCJlj+M/AgBVhF/0PAH6/D/HkDxOGAAAAAElFTkSuQmCC");
}

// Visibility
// -------------------------

.cropper-hide {
  position: absolute;
  display: block;
  width: 0;
  height: 0;
}

.cropper-hidden {
  display: none !important;
}

// Cursors
// -------------------------

.cropper-move {
  cursor: move;
}

.cropper-crop {
  cursor: crosshair;
}

.cropper-disabled {
  .cropper-drag-box, .cropper-face, .cropper-line, .cropper-point {
    cursor: not-allowed;
  }
}
