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

340 lines
7.8 KiB
SCSS
Raw Normal View History

2019-04-30 11:11:25 +08:00
.#{$ns}Tooltip {
2019-12-06 09:58:08 +08:00
position: absolute;
top: 0;
left: 0;
font-family: inherit;
border-radius: var(--borderRadius);
min-width: var(--Tooltip-minWidth);
max-width: var(--Tooltip-maxWidth);
2019-12-06 09:58:08 +08:00
text-align: left;
white-space: normal;
z-index: $zindex-tooltip;
word-wrap: break-word;
background: var(--Tooltip-bg);
box-shadow: var(--Tooltip-boxShadow);
2019-12-06 09:58:08 +08:00
&-arrow {
2019-04-30 11:11:25 +08:00
position: absolute;
2019-12-06 09:58:08 +08:00
display: block;
width: var(--Tooltip-arrow-width);
height: var(--Tooltip-arrow-height);
margin-left: calc(var(--Tooltip-arrow-width) * -1 / 2);
2019-12-06 09:58:08 +08:00
left: 50%;
&::before,
&::after {
position: absolute;
display: block;
content: '';
border-color: transparent;
border-style: solid;
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
&--top {
margin-top: calc(var(--Tooltip-arrow-height) * -1 - #{px2rem(2px)});
2019-11-13 14:46:47 +08:00
2019-12-06 09:58:08 +08:00
.#{$ns}Tooltip-arrow {
bottom: calc(
(var(--Tooltip-arrow-height) + var(--Tooltip-borderWidth)) * -1
);
2019-11-13 14:46:47 +08:00
}
2019-12-06 09:58:08 +08:00
.#{$ns}Tooltip-arrow::before,
.#{$ns}Tooltip-arrow::after {
border-width: var(--Tooltip-arrow-height)
calc(var(--Tooltip-arrow-width) / 2) 0;
2019-12-06 09:58:08 +08:00
}
.#{$ns}Tooltip-arrow::before {
bottom: 0;
}
.#{$ns}Tooltip-arrow::after {
bottom: var(--Tooltip-borderWidth);
border-top-color: var(--Tooltip-arrow-color);
2019-12-06 09:58:08 +08:00
}
}
&--right {
margin-left: calc(var(--Tooltip-arrow-height) + #{px2rem(2px)});
2019-12-06 09:58:08 +08:00
.#{$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);
2019-12-06 09:58:08 +08:00
top: 50%;
}
2019-12-06 09:58:08 +08:00
.#{$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;
2019-04-30 11:11:25 +08:00
}
2019-12-06 09:58:08 +08:00
.#{$ns}Tooltip-arrow::before {
left: 0;
}
2019-11-13 14:46:47 +08:00
2019-12-06 09:58:08 +08:00
.#{$ns}Tooltip-arrow::after {
left: var(--Tooltip-borderWidth);
border-right-color: var(--Tooltip-arrow-color);
2019-04-30 11:11:25 +08:00
}
2019-12-06 09:58:08 +08:00
}
&--bottom {
margin-top: calc(var(--Tooltip-arrow-height) + #{px2rem(2px)});
2019-04-30 11:11:25 +08:00
2019-12-06 09:58:08 +08:00
.#{$ns}Tooltip-arrow {
top: calc(
(var(--Tooltip-arrow-height) + var(--Tooltip-borderWidth)) * -1
);
2019-04-30 11:11:25 +08:00
}
2019-12-06 09:58:08 +08:00
.#{$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);
2019-04-30 11:11:25 +08:00
}
2019-12-06 09:58:08 +08:00
.#{$ns}Tooltip-arrow::before {
top: 0;
2019-07-09 16:29:48 +08:00
}
2019-12-06 09:58:08 +08:00
.#{$ns}Tooltip-arrow::after {
top: var(--Tooltip-borderWidth);
border-bottom-color: var(--Tooltip-arrow-color);
2019-07-09 16:29:48 +08:00
}
2019-12-06 09:58:08 +08:00
// 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);
2019-12-06 09:58:08 +08:00
content: '';
border-bottom: var(--Tooltip-borderWidth) solid var(--Tooltip-title-bg);
2019-07-09 16:29:48 +08:00
}
2019-12-06 09:58:08 +08:00
}
2019-07-09 16:29:48 +08:00
2019-12-06 09:58:08 +08:00
&--left {
margin-left: calc(var(--Tooltip-arrow-height) * -1 - #{px2rem(2px)});
2019-12-06 09:58:08 +08:00
.#{$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);
2019-12-06 09:58:08 +08:00
top: 50%;
2019-07-09 16:29:48 +08:00
}
2019-12-06 09:58:08 +08:00
.#{$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);
2019-04-30 11:11:25 +08:00
}
2019-12-06 09:58:08 +08:00
.#{$ns}Tooltip-arrow::before {
right: 0;
}
.#{$ns}Tooltip-arrow::after {
right: var(--Tooltip-borderWidth);
border-left-color: var(--Tooltip-arrow-color);
2019-12-06 09:58:08 +08:00
}
}
&-title {
padding: var(--Tooltip-title-paddingY) var(--Tooltip-title-paddingX) 0;
2019-12-06 09:58:08 +08:00
margin-bottom: 0; // Reset the default from Reboot
font-size: var(--fontSizeBase);
color: var(--Tooltip-title-color);
font-weight: var(--Tooltip-fontWeight);
border-top-left-radius: calc(
var(--Tooltip-borderRadius) - var(--Tooltip-borderWidth)
);
border-top-right-radius: calc(
var(--Tooltip-borderRadius) - var(--Tooltip-borderWidth)
);
2022-03-01 10:23:17 +08:00
font-weight: var(--Tooltip-title-fontWeight);
2019-12-06 09:58:08 +08:00
&:empty {
display: none;
}
}
&-body {
color: var(--Tooltip-body-color);
padding: var(--Tooltip-body-paddingY) var(--Tooltip-body-paddingX);
word-break: break-all;
text-align: left;
2019-12-06 09:58:08 +08:00
}
2022-03-01 10:23:17 +08:00
&--dark {
background: var(--Tooltip-bg--dark);
border: none;
box-shadow: var(--Tooltip-boxShadow--dark);
.#{$ns}Tooltip-title {
color: var(--Tooltip-title-color--dark);
background: transparent;
border-bottom: none;
&::before {
border-bottom-color: transparent;
}
}
.#{$ns}Tooltip-body {
color: var(--Tooltip-body-color--dark);
}
$placements: top left right bottom;
&.#{$ns}Tooltip--top {
.#{$ns}Tooltip-arrow {
&::before {
border-width: 0;
}
&::after {
border-top-color: var(--Tooltip-arrow-color--dark);
}
}
}
&.#{$ns}Tooltip--bottom {
.#{$ns}Tooltip-arrow {
&::before {
border-width: 0;
}
&::after {
border-bottom-color: var(--Tooltip-arrow-color--dark);
}
}
}
&.#{$ns}Tooltip--left {
.#{$ns}Tooltip-arrow {
&::before {
border-width: 0;
}
&::after {
border-left-color: var(--Tooltip-arrow-color--dark);
}
}
}
&.#{$ns}Tooltip--right {
.#{$ns}Tooltip-arrow {
&::before {
border-width: 0;
}
&::after {
border-right-color: var(--Tooltip-arrow-color--dark);
}
}
}
}
}
.#{$ns}TooltipWrapper {
&--inline {
display: inline-block;
}
2019-12-06 09:58:08 +08:00
}
@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);
2019-12-06 09:58:08 +08:00
text-align: left;
2020-06-13 18:31:54 +08:00
white-space: normal;
width: max-content;
box-sizing: content-box;
2020-06-13 18:31:54 +08:00
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);
2019-12-06 09:58:08 +08:00
left: 100%;
color: var(--Tooltip--attr-color);
padding: var(--Tooltip--attr-paddingY) var(--Tooltip--attr-paddingX);
2019-12-06 09:58:08 +08:00
display: none;
animation-duration: var(--animation-duration);
2019-12-06 09:58:08 +08:00
animation-fill-mode: both;
2020-06-13 18:31:54 +08:00
@media screen and (min-width: 0\0) {
2020-06-13 18:31:54 +08:00
white-space: nowrap;
max-width: unset;
}
2019-12-06 09:58:08 +08:00
}
&: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);
2019-12-06 09:58:08 +08:00
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;
2019-12-06 09:58:08 +08:00
}
&[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;
2019-12-06 09:58:08 +08:00
}
&[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;
2019-12-06 09:58:08 +08:00
}
&:hover:active:after {
content: '';
display: none !important;
}
}