@import "./variables.scss";
#app {
  .main-container {
    height: 100%;
    transition: margin-left 0.28s;
    margin-left: $base-sidebar-width;
    position: relative;
  }

  .sidebarHide {
    margin-left: 0 !important;
  }

  .sidebar-container {
    -webkit-transition: width 0.28s;
    transition: width 0.28s;
    width: $base-sidebar-width !important;
    background-color: $base-menu-background;
    height: 100%;
    position: fixed;
    font-size: 0px;
    top: 0;
    bottom: 0;
    left: 0;
    z-index: 1001;
    overflow: hidden;
    /*  -webkit-box-shadow: 2px 0 6px rgba(0, 21, 41, 0.35);
    box-shadow: 0px 0px 8px 0px rgba(0, 0, 0, 0.1); */

    // reset element-ui css
    .horizontal-collapse-transition {
      transition: 0s width ease-in-out, 0s padding-left ease-in-out,
        0s padding-right ease-in-out;
    }

    .scrollbar-wrapper {
      overflow-x: hidden !important;
    }

    .el-scrollbar__bar.is-vertical {
      right: 0px;
    }

    .el-scrollbar {
      height: 100%;
    }

    &.has-logo {
      .el-scrollbar {
        height: calc(100% - 100px);
      }
    }

    .is-horizontal {
      display: none;
    }

    a {
      display: inline-block;
      width: 100%;
      overflow: hidden;
    }

    .svg-icon {
      font-size: 16px;
      margin-right: 8px;
    }

    .el-menu {
      border: none;
      height: 100%;
      width: 100% !important;
    }

    .el-menu-item,
    .el-submenu__title {
      overflow: hidden !important;
      text-overflow: ellipsis !important;
      white-space: nowrap !important;
      border-radius: 8px !important;
      margin: 4px 0; /* 添加上下间距 */
      height: 40px;
      line-height: 40px;
      font-weight: 500;
      font-family: PingFangSC, PingFang SC;
      display: flex !important;
      align-items: center !important; // 纵向居中
      &:hover {
        background-color: $base-sub-menu-hover !important;
      }
    }
    // 菜单选中状态 - 白色效果 🌟
    .el-menu-item.is-active {
      background-color: $base-menu-active-background !important;
      color: $base-menu-color-active !important;

      &:hover {
        background-color: $base-sub-menu-hover !important;
      }
    }
    // 侧边栏收缩hover状态
    .submenu-title-noDropdown,
    .el-submenu__title {
      /*    &:hover {
        background-color: rgba(0, 0, 0, 0.06) !important;
      } */
    }

    & .theme-dark .is-active > .el-submenu__title {
      color: $base-menu-color-active !important;
      // 二级菜单选中状态下箭头颜色
      .el-submenu__icon-arrow.el-icon-arrow-down {
        &::before {
          color: #4a7ff8;
        }
      }
    }

    & .nest-menu .el-submenu > .el-submenu__title,
    & .el-submenu .el-menu-item {
      min-width: calc(#{$base-sidebar-width} - 32px) !important;
      border-radius: 8px !important;
      font-weight: 400;
      font-family: PingFangSC, PingFang SC;
      display: flex;
      align-items: center;

      &:hover {
        background-color: rgba(202, 210, 228, 0.3) !important;
      }
      // 添加二级菜单选中样式 🌟
      &.is-active {
        background-color: $base-menu-active-background !important;
        color: $base-menu-color-active !important;

        &:hover {
          background-color: darken($base-menu-active-background, 5%) !important;
        }
      }
    }

    & .theme-dark .nest-menu .el-submenu > .el-submenu__title,
    & .theme-dark .el-submenu .el-menu-item {
      background-color: $base-sub-menu-background;
      border-radius: 8px !important;

      &:hover {
        background-color: $base-sub-menu-hover !important;
      }
    }
  }

  .hideSidebar {
    .submenu-title-noDropdown {
      // 具体样式
      &:hover {
        // 收缩状态下没有子菜单的悬停颜色
        background-color: transparent !important;
      }
    }
    .sidebar-container {
      width: 80px !important;
    }
    // 在这里添加收缩状态下二级菜单的样式 ✨
    .el-submenu.is-active {
      background-color: #fff !important; // 收缩状态下的背景色
      .el-submenu__title {
        &:hover {
          // 收缩状态下选中菜单的悬停颜色
          background-color: #fff !important;
        }
      }
    }
    .el-submenu {
      border-radius: 8px;
      .el-submenu__title {
        &:hover {
          // 收缩状态下有子菜单的悬停颜色
          background: transparent !important;
        }
      }
    }

    .nest-menu .el-submenu > .el-submenu__title,
    .el-submenu .el-menu-item {
      background-color: #fff !important; // 二级菜单普通状态背景色
      border-radius: 8px !important;

      &.is-active {
        background-color: #fff !important; // 二级菜单选中状态背景色
        color: #4a7ff8 !important;
      }
    }
    .main-container {
      margin-left: 68px;
    }

    .submenu-title-noDropdown {
      padding: 0 !important;
      position: relative;

      .el-tooltip {
        padding: 0 !important;

        .svg-icon {
          margin-left: 17px;
        }
      }
    }

    .el-submenu {
      overflow: hidden;

      & > .el-submenu__title {
        padding: 0 !important;

        .svg-icon {
          margin-left: 17px;
        }
      }
    }

    .el-menu--collapse {
      .el-submenu {
        & > .el-submenu__title {
          & > span {
            height: 0;
            width: 0;
            overflow: hidden;
            visibility: hidden;
            display: inline-block;
          }
        }
      }
    }
  }

  // 展开状态样式控制 ✨
  .sidebar-container:not(.el-menu--collapse) {
    // 一级菜单图标显示
    & > .el-menu > .el-submenu > .el-submenu__title .svg-icon {
      display: inline-block !important;
      width: 1.2em;
      height: 1.2em;
      margin-right: 8px;
    }

    // 二级+菜单图标隐藏 🌈
    .el-menu--inline {
      .svg-icon {
        display: none !important;
      }

      // 三级菜单特殊处理 🎯
      .el-menu--inline {
        .svg-icon {
          display: none !important;
        }
      }
    }
  }

  .el-menu--collapse .el-menu .el-submenu {
    min-width: $base-sidebar-width !important;
  }

  // mobile responsive
  .mobile {
    .main-container {
      margin-left: 0px;
    }

    .sidebar-container {
      transition: transform 0.28s;
      width: 80% !important; // 移动端侧边栏宽度为屏幕的80%
      max-width: 280px; // 最大宽度限制
      min-width: 200px; // 最小宽度限制
      position: fixed;
      top: 0;
      left: 0;
      height: 100vh;
      z-index: 1000;
      box-shadow: 2px 0 8px rgba(0, 0, 0, 0.15);
      background-color: #fff !important; // 移动端侧边栏白色背景

      // 覆盖菜单背景色
      ::v-deep .el-menu {
        background-color: #fff !important;
      }

      // 覆盖子菜单背景色
      ::v-deep .el-submenu .el-menu {
        background-color: #fff !important;
      }

      // 覆盖菜单项背景色
      ::v-deep .el-menu-item,
      ::v-deep .el-submenu__title {
        background-color: #fff !important;

        &:hover {
          background-color: rgba(242, 242, 242, 1) !important;
        }
      }
    }

    &.hideSidebar {
      .sidebar-container {
        pointer-events: none;
        transition-duration: 0.3s;
        transform: translate3d(-100%, 0, 0); // 完全移出屏幕
      }
    }
  }

  .withoutAnimation {
    .main-container,
    .sidebar-container {
      transition: none;
    }
  }
}

// when menu collapsed
.el-menu--vertical {
  & > .el-menu {
    .svg-icon {
      margin-right: 16px;
    }
  }
  // 设置整个弹出菜单容器的背景色 💖
  & > .el-menu--popup {
    background-color: #fff !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
    padding: 8px !important; // 上下12px，左右8px
    width: max-content !important; // 改为真正的宽度自适应 ✨
    min-width: 120px !important; // 设置最小宽度
    max-width: 300px !important; // 设置最大宽度
  }

  .nest-menu .el-submenu {
    background-color: #fff !important;
  }
  .nest-menu .el-submenu > .el-submenu__title,
  .el-menu-item {
    height: auto !important; // 改为自动高度，让padding决定高度
    line-height: 20px !important; // 调整行高
    margin: 8px 0 !important; // 调整间距
    padding: 5px 24px !important;
    background-color: #fff !important;
    border-radius: 8px !important;
    span {
      margin-right: 15px;
    }
    .el-submenu__icon-arrow.el-icon-arrow-right {
      //收缩状态下箭头样式
      font-size: 16px;
      font-weight: 600;
    }
    &:hover {
      background-color: rgba(242, 242, 242, 1) !important;
      .el-submenu__icon-arrow.el-icon-arrow-right {
        transform: rotateZ(270deg);
        &::before {
          color: #4a7ff8 !important;
        }
      }
    }

    &.is-active {
      background-color: rgba(242, 242, 242, 1) !important; // 选中状态背景色
      color: rgba(74, 127, 248, 1) !important; // 选中状态字体颜色
    }
  }

  /*   .el-menu-item.is-active {
    background-color: $base-menu-active-background !important; // 🌈 使用变量设置选中背景色
    color: $base-menu-color-active !important;
    font-weight: 600;

    &:hover {
      background-color: darken(
        $base-menu-active-background,
        5%
      ) !important; // 🎨 悬停时稍深
    }
  }
 */
  // 子菜单选中状态
  .el-submenu.is-active .el-submenu__title {
    color: $base-menu-color-active !important;
  }
  // the scroll bar appears when the subMenu is too long
  > .el-menu--popup {
    max-height: 100vh;
    overflow-y: auto;

    &::-webkit-scrollbar-track-piece {
      background: #d3dce6;
    }

    &::-webkit-scrollbar {
      width: 6px;
    }

    &::-webkit-scrollbar-thumb {
      background: #99a9bf;
      border-radius: 20px;
    }
  }
}
.sidebar-container {
  padding: 0 16px; /* 添加这行来设置整体内边距 */
}
// 添加子菜单箭头样式覆盖
.el-submenu__icon-arrow {
  position: absolute;
  top: 50%;
  right: 16px !important; /* 修改为0，并添加!important确保覆盖 */
  margin-top: -7px;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
  font-size: 16px;
  color: #999;
  transform: rotateZ(270deg);
}
// 侧边栏收缩时隐藏箭头 ✨
.hideSidebar {
  .el-submenu__icon-arrow {
    display: none !important;
  }
}
