amis/packages/amis-ui/scss/components/_dropdown.scss

146 lines
2.9 KiB
SCSS
Raw Normal View History

2019-04-30 11:11:25 +08:00
.#{$ns}DropDown {
2019-12-06 09:58:08 +08:00
position: relative;
display: inline-block;
2019-04-30 11:11:25 +08:00
2019-12-06 09:58:08 +08:00
&-caret {
margin-left: var(--DropDown-caret-marginLeft);
2020-06-08 18:23:56 +08:00
display: inline-block;
vertical-align: top;
transition: transform var(--animation-duration) ease;
2020-06-08 15:49:45 +08:00
> svg {
width: px2rem(10px);
height: px2rem(10px);
top: 0.125em;
}
2019-12-06 09:58:08 +08:00
}
2019-04-30 11:11:25 +08:00
2020-06-08 18:23:56 +08:00
&.is-opened &-caret {
transform: rotate(180deg);
}
&.is-actived {
.#{$ns}Button {
color: var(--link-color);
}
}
2019-12-06 09:58:08 +08:00
&--block {
display: block;
2019-04-30 11:11:25 +08:00
2019-12-06 09:58:08 +08:00
.#{$ns}Button {
display: block;
2019-04-30 11:11:25 +08:00
}
2019-12-06 09:58:08 +08:00
}
2019-04-30 11:11:25 +08:00
2019-12-06 09:58:08 +08:00
&-menu {
background: var(--DropDown-menu-bg);
2019-12-06 09:58:08 +08:00
list-style: none;
padding: var(--DropDown-menu-paddingY) var(--DropDown-menu-paddingX);
margin: 0;
min-width: var(--DropDown-menu-minWidth);
2019-12-06 09:58:08 +08:00
text-align: left;
border: none;
user-select: none;
&-root {
position: absolute;
z-index: $zindex-dropdown;
top: 100%;
left: 0;
margin: px2rem(1px) 0 0;
border: none;
border-radius: var(--DropDown-menu-borderRadius);
box-shadow: var(--DropDown-menu-boxShadow);
min-width: var(--DropDown-menu-minWidth);
overflow-y: auto;
overflow-x: hidden;
max-height: px2rem(300px);
}
2019-12-06 09:58:08 +08:00
}
2019-04-30 11:11:25 +08:00
2019-12-06 09:58:08 +08:00
&--alignRight &-menu {
left: auto;
right: 0;
}
2019-04-30 11:11:25 +08:00
2019-12-06 09:58:08 +08:00
&-menuItem,
&-menu > li {
padding: var(--DropDown-menuItem-paddingY) var(--DropDown-menuItem-paddingX);
2019-12-06 09:58:08 +08:00
white-space: nowrap;
box-sizing: border-box;
height: var(--DropDown-menu-height);
2019-12-06 09:58:08 +08:00
vertical-align: middle;
user-select: none;
color: var(--DropDown-menuItem-color);
2021-04-08 12:52:33 +08:00
text-decoration: var(--link-decoration);
2019-04-30 11:11:25 +08:00
2019-12-06 09:58:08 +08:00
&:hover {
background: var(--DropDown-menuItem-onHover-bg);
color: var(--DropDown-menuItem-onHover-color);
2019-04-30 11:11:25 +08:00
}
&.is-active {
background: var(--DropDown-menuItem-onHover-bg);
color: var(--DropDown-menuItem-onActive-color);
}
2019-12-06 09:58:08 +08:00
&:not(.is-disabled),
&:not(.disabled) {
cursor: pointer;
2019-04-30 11:11:25 +08:00
}
&.is-disabled {
cursor: not-allowed;
// pointer-events: none;
color: var(--DropDown-menuItem-onDisabled-color);
filter: grayscale(80%);
}
2019-12-06 09:58:08 +08:00
&.#{$ns}DropDown-divider {
height: px2rem(1px);
margin: px2rem(9px) 0;
overflow: hidden;
background: var(--DropDown-menu-borderColor);
2019-12-06 09:58:08 +08:00
padding: 0;
2019-04-30 11:11:25 +08:00
}
&.#{$ns}DropDown-groupTitle {
height: inherit;
font-size: var(--fontSizeSm);
padding: var(--gap-xs) var(--gap-xs);
padding-left: var(--gap-sm);
color: var(--DropDown-group-color);
flex-grow: 1;
cursor: default;
&:hover {
background: none;
}
span {
white-space: nowrap;
}
& ~ .#{$ns}DropDown-button {
padding-left: var(--gap-lg);
}
}
2019-12-06 09:58:08 +08:00
}
&-menu > li a {
color: inherit;
2019-12-06 09:58:08 +08:00
display: block;
text-decoration: none;
}
&-popover {
border: none;
box-shadow: none;
}
2020-06-16 14:30:25 +08:00
> .#{$ns}Button {
min-width: unset;
}
}