amis2/scss/components/_tooltip.scss
吴多益 35711ace89
feat:增加 animation-duration,可以控制所有动画时长,也能用于一次性关闭所有动画效果 (#1303)
* feat:增加 animation-duration,可以控制所有动画时长,也能用于一次性关闭所有动画效果

* 补充文档
2021-01-04 16:45:43 +08:00

273 lines
6.7 KiB
SCSS

.#{$ns}Tooltip {
position: absolute;
top: 0;
left: 0;
font-family: inherit;
border-radius: var(--borderRadius);
min-width: var(--Tooltip-minWidth);
max-width: var(--Tooltip-maxWidth);
text-align: left;
white-space: normal;
z-index: $zindex-tooltip;
word-wrap: break-word;
background: var(--Tooltip-bg);
border: var(--Tooltip-borderWidth) solid var(--Tooltip-borderColor);
box-shadow: var(--Tooltip-boxShadow);
&-arrow {
position: absolute;
display: block;
width: var(--Tooltip-arrow-width);
height: var(--Tooltip-arrow-height);
margin-left: calc(var(--Tooltip-arrow-width) * -1 / 2);
left: 50%;
&::before,
&::after {
position: absolute;
display: block;
content: '';
border-color: transparent;
border-style: solid;
}
}
&--top {
margin-top: calc(var(--Tooltip-arrow-height) * -1 - #{px2rem(2px)});
.#{$ns}Tooltip-arrow {
bottom: calc(
(var(--Tooltip-arrow-height) + var(--Tooltip-borderWidth)) * -1
);
}
.#{$ns}Tooltip-arrow::before,
.#{$ns}Tooltip-arrow::after {
border-width: var(--Tooltip-arrow-height)
calc(var(--Tooltip-arrow-width) / 2) 0;
}
.#{$ns}Tooltip-arrow::before {
bottom: 0;
border-top-color: var(--Tooltip-arrow-outerColor);
}
.#{$ns}Tooltip-arrow::after {
bottom: var(--Tooltip-borderWidth);
border-top-color: var(--Tooltip-arrow-color);
}
}
&--right {
margin-left: calc(var(--Tooltip-arrow-height) + #{px2rem(2px)});
.#{$ns}Tooltip-arrow {
left: calc(var(--Tooltip-borderWidth) * -1);
width: var(--Tooltip-arrow-height);
height: var(--Tooltip-arrow-width);
margin-top: calc(var(--Tooltip-arrow-width) / -2);
top: 50%;
}
.#{$ns}Tooltip-arrow::before,
.#{$ns}Tooltip-arrow::after {
border-width: calc(var(--Tooltip-arrow-width) / 2)
var(--Tooltip-arrow-height) calc(var(--Tooltip-arrow-width) / 2) 0;
}
.#{$ns}Tooltip-arrow::before {
left: 0;
border-right-color: var(--Tooltip-arrow-outerColor);
}
.#{$ns}Tooltip-arrow::after {
left: var(--Tooltip-borderWidth);
border-right-color: var(--Tooltip-arrow-color);
}
}
&--bottom {
margin-top: calc(var(--Tooltip-arrow-height) + #{px2rem(2px)});
.#{$ns}Tooltip-arrow {
top: calc(
(var(--Tooltip-arrow-height) + var(--Tooltip-borderWidth)) * -1
);
}
.#{$ns}Tooltip-arrow::before,
.#{$ns}Tooltip-arrow::after {
border-width: 0 calc(var(--Tooltip-arrow-width) / 2)
var(--Tooltip-arrow-height) calc(var(--Tooltip-arrow-width) / 2);
}
.#{$ns}Tooltip-arrow::before {
top: 0;
border-bottom-color: var(--Tooltip-arrow-outerColor);
}
.#{$ns}Tooltip-arrow::after {
top: var(--Tooltip-borderWidth);
border-bottom-color: var(--Tooltip-arrow-color);
}
// This will remove the popover-header's border just below the arrow
.#{$ns}Tooltip-title::before {
position: absolute;
top: 0;
left: 50%;
display: block;
width: var(--Tooltip-arrow-width);
margin-left: calc(var(--Tooltip-arrow-width) / -2);
content: '';
border-bottom: var(--Tooltip-borderWidth) solid var(--Tooltip-title-bg);
}
}
&--left {
margin-left: calc(var(--Tooltip-arrow-height) * -1 - #{px2rem(2px)});
.#{$ns}Tooltip-arrow {
left: auto;
right: calc(
(var(--Tooltip-arrow-height) + var(--Tooltip-borderWidth)) * -1
);
width: var(--Tooltip-arrow-height);
height: var(--Tooltip-arrow-width);
margin-top: calc(var(--Tooltip-arrow-width) * -1 / 2);
top: 50%;
}
.#{$ns}Tooltip-arrow::before,
.#{$ns}Tooltip-arrow::after {
border-width: calc(var(--Tooltip-arrow-width) / 2) 0
calc(var(--Tooltip-arrow-width) / 2) var(--Tooltip-arrow-height);
}
.#{$ns}Tooltip-arrow::before {
right: 0;
border-left-color: var(--Tooltip-arrow-outerColor);
}
.#{$ns}Tooltip-arrow::after {
right: var(--Tooltip-borderWidth);
border-left-color: var(--Tooltip-arrow-color);
}
}
&-title {
padding: var(--Tooltip-title-paddingY) var(--Tooltip-title-paddingX);
margin-bottom: 0; // Reset the default from Reboot
font-size: var(--fontSizeBase);
color: var(--Tooltip-title-color);
background: var(--Tooltip-title-bg);
border-bottom: var(--Tooltip-borderWidth) solid
var(--Tooltip-title-borderBottom-color);
border-top-left-radius: calc(
var(--Tooltip-borderRadius) - var(--Tooltip-borderWidth)
);
border-top-right-radius: calc(
var(--Tooltip-borderRadius) - var(--Tooltip-borderWidth)
);
&:empty {
display: none;
}
}
&-body {
color: var(--Tooltip-body-color);
padding: var(--Tooltip-body-paddingY) var(--Tooltip-body-paddingX);
}
}
@keyframes tooltipIn {
from {
opacity: 0;
margin: 0;
}
}
[data-tooltip] {
position: relative;
&:after {
pointer-events: none;
left: 0;
top: 50%;
transform: translateY(-50%);
position: absolute;
content: attr(data-tooltip);
font-size: var(--Tooltip--attr-fontSize);
line-height: var(--Tooltip--attr-lineHeigt);
text-align: left;
white-space: normal;
width: max-content;
box-sizing: content-box;
max-width: 300px;
background: var(--Tooltip--attr-bg);
border: var(--Tooltip--attr-borderWidth) solid
var(--Tooltip--attr-borderColor);
border-radius: var(--Tooltip--attr-borderRadius);
box-shadow: var(--Tooltip--attr-boxShadow);
left: 100%;
color: var(--Tooltip--attr-color);
padding: var(--Tooltip--attr-paddingY) var(--Tooltip--attr-paddingX);
display: none;
animation-duration: var(--animation-duration);
animation-fill-mode: both;
@media screen and (min-width: 0\0) {
white-space: nowrap;
max-width: unset;
}
}
&:not(.is-disabled):hover:after {
display: inline-block;
animation-name: tooltipIn;
opacity: 1;
z-index: $zindex-tooltip;
margin: 0 0 0 var(--Tooltip--attr-gap);
opacity: 1;
}
&[data-position='bottom']:after {
left: 50%;
top: 100%;
transform: translateX(-50%);
}
&[data-position='bottom']:hover:after {
margin: var(--Tooltip--attr-gap) 0 0 0;
}
&[data-position='left']:after {
top: 50%;
right: 100%;
left: auto;
transform: translateY(-50%);
}
&[data-position='left']:hover:after {
margin: 0 var(--Tooltip--attr-gap) 0 0;
}
&[data-position='top']:after {
left: 50%;
top: auto;
bottom: 100%;
transform: translateX(-50%);
}
&[data-position='top']:hover:after {
margin: calc(var(--Tooltip--attr-gap) * -1) 0 0 0;
}
&:hover:active:after {
content: '';
display: none !important;
}
}