BigW Consortium Gitlab

search.scss 4.91 KB
.search-results {
  .search-result-row {
    border-bottom: 1px solid $border-color;
    padding-bottom: $gl-padding;
    margin-bottom: $gl-padding;

    &:last-child {
      border-bottom: none;
    }
  }

  .blob-result {
    margin: 5px 0;
  }
}

.search form:hover,
.file-finder-input:hover,
.issuable-search-form:hover,
.search-text-input:hover,
.form-control:hover {
  border-color: lighten($dropdown-input-focus-border, 20%);
  box-shadow: 0 0 4px lighten($search-input-focus-shadow-color, 20%);
}

input[type="checkbox"]:hover {
  box-shadow: 0 0 2px 2px lighten($search-input-focus-shadow-color, 20%), 0 0 0 1px lighten($search-input-focus-shadow-color, 20%);
}

.search {
  margin-right: 10px;
  margin-left: 10px;
  margin-top: ($header-height - 35) / 2;

  form {
    @extend .form-control;
    margin: 0;
    padding: 4px;
    width: $search-input-width;
    line-height: 24px;

    &:hover {
      border-color: lighten($dropdown-input-focus-border, 20%);
      box-shadow: 0 0 4px lighten($search-input-focus-shadow-color, 20%);
    }
  }

  .location-text {
    font-style: normal;
  }

  .search-input {
    border: none;
    font-size: 14px;
    padding: 0 20px 0 0;
    margin-left: 5px;
    line-height: 25px;
    width: 98%;
  }

  .location-badge {
    line-height: 25px;
    padding: 0 5px;
    border-radius: $border-radius-default;
    font-size: 14px;
    font-style: normal;
    color: $note-disabled-comment-color;
    display: inline-block;
    background-color: $gray-normal;
    vertical-align: top;
    cursor: default;
  }

  .search-input-container {
    display: -webkit-flex;
    display: flex;
    position: relative;
  }

  .search-input-wrap {
    // Fallback if flexbox is not supported
    display: inline-block;
  }

  .search-input-wrap {
    width: 100%;

    .search-icon,
    .clear-icon {
      position: absolute;
      right: 5px;
      top: 0;
      color: $location-icon-color;

      &::before {
        font-family: FontAwesome;
        font-weight: normal;
        font-style: normal;
      }
    }

    .search-icon {
      @extend .fa-search;
      transition: color 0.15s;
      -webkit-user-select: none;
      -moz-user-select: none;
      -ms-user-select: none;
    }

    .clear-icon {
      @extend .fa-times;
      display: none;
    }

    // Rewrite position. Dropdown menu should be relative to .search-input-container
    .dropdown {
      position: static;
    }

    .dropdown-header {
      text-transform: uppercase;
      font-size: 11px;
    }

    // Custom dropdown positioning
    .dropdown-menu {
      transition-property: opacity, transform;
      transition-duration: 250ms, 250ms;
      transition-delay: 0ms, 25ms;
      transition-timing-function: $dropdown-animation-timing;
      transform: translateY(0);
      opacity: 0;
      display: block;
      left: -5px;
      padding: 0;

      ul {
        padding: 10px 0;
      }
    }

    .dropdown-content {
      max-height: 350px;
    }
  }

  &.search-active {
    form {
      @extend .form-control:focus;
      border-color: $dropdown-input-focus-border;
      box-shadow: 0 0 4px $search-input-focus-shadow-color;
    }

    .location-badge {
      transition: all 0.15s;
      background-color: $location-badge-active-bg;
      color: $white-light;
    }

    .search-input-wrap {
      i {
        color: $layout-link-gray;
      }
    }

    .dropdown-menu {
      transition-duration: 100ms, 75ms;
      transition-delay: 75ms, 100ms;
      transform: translateY(13px);
      opacity: 1;
    }
  }

  &.has-value {
    .search-icon {
      display: none;
    }

    .clear-icon {
      cursor: pointer;
      display: block;
    }
  }

  &.has-location-badge {
    .search-input-wrap {
      width: 68%;
    }
  }
}

.search-holder {
  @media (min-width: $screen-sm-min) {
    display: -webkit-flex;
    display: flex;
  }

  .search-field-holder,
  .project-filter-form {
    -webkit-flex: 1 0 auto;
    flex: 1 0 auto;
    position: relative;
    margin-right: 0;

    @media (min-width: $screen-sm-min) {
      margin-right: 5px;
    }
  }

  .search-icon {
    position: absolute;
    left: 10px;
    top: 10px;
    color: $gray-darkest;
    pointer-events: none;
  }

  .search-text-input,
  .project-filter-form-field {
    padding-left: $gl-padding + 15px;
    padding-right: $gl-padding + 15px;
  }

  .btn-search,
  .btn-new {
    width: 100%;
    margin-top: 5px;

    @media (min-width: $screen-sm-min) {
      width: auto;
      margin-top: 0;
      margin-left: 5px;
    }
  }

  .dropdown {
    @media (min-width: $screen-sm-min) {
      margin-left: 5px;
      margin-right: 5px;
    }
  }

  .dropdown-menu-toggle {
    width: 100%;
    margin-top: 5px;

    @media (min-width: $screen-sm-min) {
      width: 180px;
      margin-top: 0;
    }
  }
}

.search-clear {
  position: absolute;
  right: 10px;
  top: 10px;
  padding: 0;
  color: $gray-darkest;
  line-height: 0;
  background: none;
  border: 0;

  &:hover,
  &:focus {
    color: $gl-link-color;
  }
}