﻿@use 'ej2-base/styles/common/mixin' as *;
@include export-module('listbox-layout') {
  /* stylelint-disable property-no-vendor-prefix */
  .e-listbox-wrapper,
  .e-listbox-container,
  .e-listboxtool-wrapper {
    -webkit-overflow-scrolling: touch;
    box-sizing: border-box;
    cursor: pointer;
    display: block;
    position: relative;
    user-select: none;
    width: $listbox-full-width;

    * {
      box-sizing: border-box;
    }

    @if $skin-name == 'fluent2' or $theme-name == 'bootstrap5.3' or $theme-name == 'bootstrap5.3-dark' {
      & {
        border-radius: $list-box-nrml-border-radius;
      }
    }
    @if $skin-name == 'tailwind3' {
      & {
        font-weight: $list-font-weight-medium;
        border-radius: $list-box-nrml-border-radius;
      }
    }

    &.e-listboxtool-container .e-list-wrap {
      @if $skin-name == 'FluentUI' or $skin-name == 'bootstrap5' or $skin-name == 'bootstrap5.3' or $skin-name == 'tailwind' {
        width: $list-tool-nrml-box-wrap-width !important; /* stylelint-disable-line declaration-no-important */
      }
      @else if $skin-name == 'material' or $skin-name == 'bootstrap4' or $skin-name == 'bootstrap' or $skin-name == 'fabric' {
        width: $list-tool-nrml-box-wrap-width !important; /* stylelint-disable-line declaration-no-important */
      }
      @else if $skin-name == 'highcontrast' {
        width: $list-tool-nrml-box-wrap-width !important; /* stylelint-disable-line declaration-no-important */
      }
    }

    & .e-list-wrap:focus-visible,
    &:focus {
      outline: none;
    }

    &.e-disabled {
      cursor: default;
      pointer-events: none;
    }

    & .e-list-item.e-disabled,
    & .e-list-item.e-disabled .e-list-icon {
      @if $skin-name == 'fluent2' or $skin-name == 'tailwind3' {
        color: $content-text-color-disabled;
        opacity: 1;
      }
    }

    &:not(.e-list-template) .e-list-nrt {
      text-align: center;
    }

    .e-list-parent {
      height: $listbox-full-height;
      min-height: $listbox-item-height;
    }

    & .e-list-item {
      border-bottom: $listbox-border-size solid;
      outline: none;

      &:focus-visible {
        @if $skin-name == 'fluent2' {
          background-color: $content-bg-color !important; /* stylelint-disable-line declaration-no-important */
          color: $content-text-color !important; /* stylelint-disable-line declaration-no-important */
          box-shadow: $secondary-shadow-focus;
        }
        @if $skin-name == 'tailwind3' {
          background-color: $content-bg-color !important; /* stylelint-disable-line declaration-no-important */
          color: $content-text-color !important; /* stylelint-disable-line declaration-no-important */
          box-shadow: $shadow-focus-ring2;
        }
      }

      &.e-disabled {
        pointer-events: none;
      }
    }

    .e-disable {
      opacity: .7;
    }

    & .e-list-group-item,
    & .e-list-item {
      @if $skin-name == 'fluent2' {
        margin: $list-group-item-margin;
      }
    }

    & .e-list-parent {
      margin: $listbox-zero-margin-padding;
      padding: $listbox-zero-margin-padding;
    }

    & .e-list-header .e-text.header,
    & .e-list-header .e-headertemplate-text.nested-header {
      display: none;
    }

    & .e-icon-back {
      margin-top: $listbox-icon-back-margin;
    }

    & .e-list-header {
      align-items: center;
      border-bottom: $list-border solid;
      display: flex;
      font-weight: $listbox-header-font-weight;
      height: $listbox-header-height;
      padding: $listbox-header-text-padding;
    }

    & .e-has-header > .e-view {
      top: $list-box-header-view-top;
    }

    & .e-but-back {
      cursor: pointer;
      padding-right: $listbox-back-padding-right;
    }

    & .e-list-group-item:first-child {
      @if $theme-name != 'bootstrap5.3' and $theme-name != 'bootstrap5.3-dark' {
        border: $zero-border;
        border-bottom: $listbox-group-first-border-bottom solid $listbox-border-bottom-color;
      }
    }

    & .e-list-group-item {
      border-bottom: $listbox-group-border-bottom solid $listbox-border-bottom-color;
      border-top: $listbox-group-border-top solid;
      font-weight: $listbox-group-item-font-weight;
      height: $listbox-groupheader-item-height;
      line-height: $listbox-groupheader-item-line-height;
      @if $theme-name == 'bootstrap5.3' or $theme-name == 'bootstrap5.3-dark' {
        padding: $list-group-item-padding;
      }
      @else {
        padding: $listbox-item-padding;
      }
    }

    & .e-icon-collapsible {
      cursor: pointer;
      font-size: $listbox-icon-collapsible-font-size;
      position: absolute;
      right: $zero-width;
      top: $list-box-half-width;
      transform: translateY(-50%);
    }

    & .e-text-content {
      height: $listbox-full-height;
      position: relative;
      vertical-align: middle;
    }

    & .e-text-content * {
      display: inline-block;
      vertical-align: middle;
    }

    & .e-text-content.e-checkbox .e-list-text {
      width: $list-text-checkbox-width;
    }

    & .e-text-content.e-checkbox.e-checkbox-left .e-list-icon + .e-list-text {
      width: $list-box-checkbox-icon-width;
    }

    & .e-text-content.e-checkbox.e-checkbox-right .e-list-icon + .e-list-text {
      width: $list-checkbox-right-icon-width;
    }

    & .e-list-item.e-checklist.e-has-child {
      .e-text-content.e-checkbox.e-checkbox-right {
        .e-list-icon + .e-list-text {
          width: $list-box-icon-child-width;
        }
      }
    }

    & .e-checkbox .e-checkbox-left {
      margin: $listbox-checkbox-left-margin;
    }

    & .e-checkbox .e-checkbox-right {
      margin: $listbox-checkbox-right-margin;
    }

    & .e-list-text {
      cursor: pointer;
      display: inline-block;
      overflow: hidden;
      text-overflow: ellipsis;
      vertical-align: top;
      white-space: nowrap;
      width: $listbox-full-width;
    }

    & .e-list-icon + .e-list-text,
    & .e-icon-wrapper .e-list-text,
    & .e-icon-wrapper.e-text-content.e-checkbox .e-list-text {
      width: $list-box-text-width;
    }

    & .e-list-icon {
      height: $listbox-list-icon-height;
      margin-right: $listbox-icon-margin-right;
      width: $listbox-list-icon-width;
    }

    & .e-content {
      overflow: hidden;
      position: relative;
    }

    & .e-list-header .e-text {
      cursor: pointer;
      text-indent: $listbox-zero-padding-margin;
    }

    & .e-text .e-headertext {
      display: inline-block;
      line-height: $listbox-header-line-height;
    }

    &.e-rtl {
      direction: rtl;

      & .e-list-icon {
        margin-left: $listbox-list-icon-margin-left;
        margin-right: $listbox-zero-padding-margin;
      }

      & .e-icon-collapsible {
        left: $zero-width;
        right: initial;
        top: $list-box-half-width;
        transform: translateY(-50%) rotate(180deg);
      }

      & .e-list-header .e-text {
        cursor: pointer;
      }

      & .e-but-back {
        transform: rotate(180deg);
      }

      & .e-icon-back {
        margin-top: $listbox-rtl-icon-back-margin;
      }

      & .e-checkbox .e-checkbox-left,
      .e-checkbox-wrapper {
        margin: $listbox-rtl-checkbox-left-margin;
        @if $skin-name == 'fluent2' {
          padding: $list-check-box-left-padding;
          vertical-align: top;
        }
      }

      & .e-checkbox .e-checkbox-right {
        margin: $listbox-rtl-checkbox-right-margin;
      }
    }

    .e-checkbox-wrapper {
      margin: $listbox-checkbox-left-margin;
      text-indent: $listbox-zero-padding-margin;
      vertical-align: middle;
      @if $skin-name == 'Material3' {
        position: relative;
      }
      @if $skin-name == 'fluent2' {
        padding: $list-checkbox-wrapper-padding;
        vertical-align: top;

        & .e-frame {
          margin: $listbox-zero-margin-padding !important; /* stylelint-disable-line declaration-no-important */
        }
      }
    }

    &.e-checkbox-right {
      .e-checkbox-wrapper {
        position: absolute;
        right: $listbox-zero-padding-margin;
        top: $checkbox-wrapper-top;
      }
    }

    .e-filter-parent {
      @if $skin-name == 'tailwind3' {
        padding: $listbox-filter-parent-padding;
      }
    }

    .e-input-group {
      @if $skin-name != 'tailwind' {
        padding: $listbox-input-grp-padding;
      }
      @if $skin-name == 'tailwind3' {
        padding: $listbox-zero-margin-padding;
      }
    }

    .e-input-focus {
      @if $skin-name != 'tailwind' {
        padding: $listbox-input-focus-padding;
      }
      @if $skin-name == 'tailwind3' {
        padding: $listbox-zero-margin-padding;
      }
    }

    .e-hidden-select {
      height: $listbox-hidden-select-height;
      opacity: 0;
      position: absolute;
      width: $listbox-full-width;
    }

    .e-placeholder {
      background-color: $badge-bgcolor;
      display: block;
      @if $skin-name == 'fluent2' {
        border: $placeholder-border solid $badge-bgcolor;
      }
      height: $listbox-placeholder-height;
    }
  }

  ejs-listbox {
    display: block;
  }

  .e-listbox-wrapper:not(.e-listbox-container),
  .e-listbox-wrapper.e-filter-list .e-list-parent {
    overflow: auto;
  }

  .e-listbox-wrapper.e-sortableclone,
  .e-listbox-container.e-sortableclone,
  .e-listboxtool-wrapper.e-sortableclone {
    border-width: $zero-border;
    overflow: visible;

    .e-list-item {
      list-style-type: none;
      @if $skin-name != 'fluent2' {
        height: $list-box-list-item-height !important; /* stylelint-disable-line declaration-no-important */
      }
    }

    .e-ripple {
      overflow: visible;

      .e-ripple-element {
        display: none;
      }
    }

    .e-list-badge {
      align-items: center;
      background-color: $badge-bgcolor;
      border: $list-border-width solid $badge-color;
      border-radius: $listbox-list-badge-border-radius;
      color: $badge-color;
      display: flex;
      font-size: $listbox-list-badge-font-size;
      height: $list-badge-height;
      justify-content: center;
      position: absolute;
      right: $list-box-list-badge-right;
      top: $list-box-list-badge-top;
      width: $list-badge-width;
    }
  }

  .e-listboxtool-wrapper.e-sortableclone{
    display: block;
  }

  .e-listboxtool-wrapper,
  .e-listboxtool-container {
    cursor: pointer;
    display: flex;

    * {
      box-sizing: border-box;
    }

    &.e-disabled {
      cursor: default;
      pointer-events: none;
    }

    .e-listbox-wrapper,
    .e-list-wrap {
      flex: 1;
    }

    &.e-right {
      .e-listbox-tool {
        margin-left: $listbox-wrapper-right-left-margin;
      }
    }

    &.e-left {
      .e-listbox-tool {
        margin-right: $listbox-wrapper-right-left-margin;
      }
    }

    .e-listbox-tool {
      border: $list-border-width solid $listbox-border-color;
      overflow: auto;
      padding: $listbox-tool-padding;
      @if $skin-name == 'tailwind3' {
        border-radius: $list-box-tool-tail-radius;
        .e-btn-icon {
          font-size: $text-base;
        }
      }
      .e-btn {
        display: list-item;
        list-style-type: none;
        margin-bottom: $listbox-tool-btn-margin-bottom;
      }
    }

    &.e-checkbox-right {
      .e-checkbox-wrapper {
        position: absolute;
        right: $listbox-zero-padding-margin;
        top: $checkbox-wrapper-top;
      }
    }
  }

  .e-rtl.e-listboxtool-wrapper,
  .e-rtl.e-listboxtool-container {
    &.e-right {
      .e-listbox-tool {
        margin-right: $listbox-wrapper-right-left-margin;
      }
    }

    &.e-left {
      .e-listbox-tool {
        margin-left: $listbox-wrapper-right-left-margin;
      }
    }
  }
}

.e-listbox-wrapper,
.e-listbox-container,
.e-listboxtool-wrapper .e-listbox-wrapper {
  &:not(.e-list-template) .e-list-item,
  .e-list-nrt,
  .e-selectall-parent {
    height: $listbox-item-height;
    line-height: $listbox-item-line-height;
    padding: $listbox-item-padding;
    position: relative;
    @if $skin-name == 'fluent2' {
      font-size: $list-box-item-font-size;
      border-radius: $list-box-item-border-radius !important; /* stylelint-disable-line declaration-no-important */
    }
  }
  
  .e-list-icon {
    display: inline;
    vertical-align: middle;
    width: $list-icon-width;
    height: $list-icon-height;
    padding-bottom: $listbox-icon-padding;
  }
}
