@import './mixins/mixins.scss'; @import './themes/vars.scss'; @mixin base-select-size-mixin ($size) { @include m($size + '-size') { @include b(virtual-scroller) { height: 100%; max-height: map-get($map: $--n-height, $key: $size) * 7.6; scrollbar-width: none; -moz-scrollbar-width: none; &::-webkit-scrollbar { width: 0; height: 0; } } @include b(scrollbar-container) { max-height: map-get($map: $--n-height, $key: $size) * 7.6; } @include b(base-select-option) { height: map-get($map: $--n-height, $key: $size); line-height: map-get($map: $--n-height, $key: $size); font-size: map-get($map: $--n-font-size, $key: $size); } @include b(base-select-group-header) { height: map-get($map: $--n-height, $key: $size); line-height: map-get($map: $--n-height, $key: $size); font-size: map-get($map: $--n-font-size, $key: $size) - 2px; } } } @include themes-mixin { @include b(base-select-menu) { @include once { @include base-select-size-mixin("small"); @include base-select-size-mixin("medium"); @include base-select-size-mixin("large"); @include base-select-size-mixin("huge"); outline: none; margin-top: 4px; margin-bottom: 4px; z-index: 0; position: relative; border-radius: 6px; transition: background-color .3s $--n-ease-in-out-cubic-bezier; font-size: $--n-secondary-text-color; @include b(base-select-menu-option-wrapper) { position: relative; width: 100%; } @include e(action) { padding: 8px 14px; font-size: 14px; } } background-color: $--base-select-menu-background-color; box-shadow: $--base-select-menu-box-shadow; @include b(base-select-group-header) { cursor: default; color: $--n-meta-text-color; padding: 0 14px; } @include b(base-select-option) { cursor: pointer; position: relative; padding: 0 14px; white-space: nowrap; transition: color .3s $--n-ease-in-out-cubic-bezier; color: map-get($map: $--base-select-menu-option-color, $key: "default"); text-overflow: ellipsis; overflow: hidden; @include m(grouped) { padding: 0 21px; } @include m(selected) { color: map-get($map: $--base-select-menu-option-color, $key: "selected"); } @include m(disabled) { color: map-get($map: $--base-select-menu-option-color, $key: "disabled"); &::after { display: none; } @include m(selected) { color: map-get($map: $--base-select-menu-option-color, $key: "disabled-selected"); &::after { border-right: 1px solid map-get($map: $--base-select-menu-option-color, $key: "disabled-selected"); border-bottom: 1px solid map-get($map: $--base-select-menu-option-color, $key: "disabled-selected"); display: block; } } cursor: not-allowed; } @include m(loading) { color: map-get($map: $--base-select-menu-option-color, $key: "disabled"); text-align: center; pointer-events: none; } } @include e(action) { border-top: 1px solid $--n-alpha-divider-color; color: $--n-secondary-text-color; } @include m(multiple) { @include b(base-select-option) { position: relative; transition: color .3s $--n-ease-in-out-cubic-bezier; padding-right: 28px; &::after { @include once { content: ''; height: 6px; width: 3px; position: absolute; right: 14px; transform: rotate(45deg) scale(.5); top: calc(50% - 4px); opacity: 0; transition: transform .3s $--n-ease-in-out-cubic-bezier, opacity .3s $--n-ease-in-out-cubic-bezier; } border-right: 1px solid $--base-select-menu-option-check-mark-color; border-bottom: 1px solid $--base-select-menu-option-check-mark-color; } @include m(selected) { background: none; &::after { opacity: 1; transform: rotate(45deg) scale(1); } } &:active { color: map-get($map: $--base-select-menu-option-color, $key: "active"); } } } } }