@cbpds/web-components
Version:
Web components for the CBP Design System.
277 lines (275 loc) • 13.7 kB
CSS
/*
* Caution: "global styles" get injected into every component and can cause file size bloat.
* These should only include SASS variables and mixins that are not written out to CSS directly
*/
/**
* @prop --cbp-tooltip-color: var(--cbp-color-text-lightest);
* @prop --cbp-tooltip-color-dark: var(--cbp-color-text-darkest);
* @prop --cbp-tooltip-color-bg: var(--cbp-color-gray-cool-80);
* @prop --cbp-tooltip-color-bg-dark: var(--cbp-color-gray-cool-5);
* @prop --cbp-tooltip-control-focus: 1px solid red;
* @prop --cbp-tooltip-control-focus-dark: 1px solid cyan;
* @prop --cbp-tooltip-padding: var(--cbp-space-inset-4x, 1rem);
* @prop --cbp-tooltip-gap: 0px;
* @prop --cbp-tooltip-offset: 0px;
* @prop --cbp-tooltip-caret-size: 15px;
* @prop --cbp-tooltip-caret-offset: calc(var(--cbp-tooltip-caret-size) / 2);
* @prop --cbp-tooltip-control-color-hover: var(--cbp-color-interactive-secondary-darker);
* @prop --cbp-tooltip-control-color-hover-dark: var(--cbp-color-interactive-secondary-lighter);
* @prop --cbp-tooltip-control-color-bg-hover: var(--cbp-color-interactive-secondary-lighter);
* @prop --cbp-tooltip-control-color-bg-hover-dark: var(--cbp-color-interactive-disabled-light);
* @prop --cbp-tooltip-control-color-focus: var(--cbp-color-text-lightest);
* @prop --cbp-tooltip-control-color-focus-dark: var(--cbp-color-text-darkest);
* @prop --cbp-tooltip-control-color-bg-focus: var(--cbp-color-interactive-focus-dark);
* @prop --cbp-tooltip-control-color-bg-focus-dark: var(--cbp-color-interactive-focus-light);
*/
:root {
--cbp-tooltip-color: var(--cbp-color-text-lightest);
--cbp-tooltip-color-dark: var(--cbp-color-text-darkest);
--cbp-tooltip-color-bg: var(--cbp-color-gray-cool-80);
--cbp-tooltip-color-bg-dark: var(--cbp-color-gray-cool-5);
--cbp-tooltip-gap: 0px;
--cbp-tooltip-offset: 0px;
--cbp-tooltip-caret-size: 14px;
--cbp-tooltip-caret-offset: calc(var(--cbp-tooltip-caret-size) / 2);
--cbp-tooltip-caret-space: var(--cbp-space-4x);
--cbp-tooltip-control-color-hover: var(--cbp-color-interactive-secondary-darker);
--cbp-tooltip-control-color-hover-dark: var(--cbp-color-text-darkest);
--cbp-tooltip-control-color-bg-hover: var(--cbp-color-interactive-secondary-lighter);
--cbp-tooltip-control-color-bg-hover-dark: var(--cbp-color-interactive-disabled-light);
--cbp-tooltip-control-color-focus: var(--cbp-color-text-lightest);
--cbp-tooltip-control-color-focus-dark: var(--cbp-color-text-darkest);
--cbp-tooltip-control-color-bg-focus: var(--cbp-color-interactive-focus-dark);
--cbp-tooltip-control-color-bg-focus-dark: var(--cbp-color-interactive-focus-light);
--cbp-tooltip-control-outline-focus: 2px solid var(--cbp-color-white);
--cbp-tooltip-control-outline-focus-dark: 2px solid var(--cbp-color-black);
--cbp-tooltip-definition-color: var(--cbp-color-interactive-primary-dark);
--cbp-tooltip-definition-color-dark: var(--cbp-color-interactive-primary-light);
--cbp-tooltip-definition-color-hover: var(--cbp-color-interactive-primary-darker);
--cbp-tooltip-definition-color-hover-dark: var(--cbp-color-interactive-primary-lighter);
--cbp-tooltip-definition-color-focus: var(--cbp-color-interactive-focus-dark);
--cbp-tooltip-definition-color-focus-dark: var(--cbp-color-interactive-focus-light);
--cbp-tooltip-definition-outline-focus: 2px solid var(--cbp-color-interactive-focus-dark);
--cbp-tooltip-definition-outline-focus-dark: 2px solid var(--cbp-color-interactive-focus-light);
}
[data-cbp-theme=light] cbp-tooltip[context*=dark]:not([context=light-always]),
[data-cbp-theme=dark] cbp-tooltip:not([context=dark-inverts]):not([context=light-always]) {
--cbp-tooltip-color-bg: var(--cbp-tooltip-color-bg-dark);
--cbp-tooltip-color: var(--cbp-tooltip-color-dark);
--cbp-tooltip-control-color-hover: var(--cbp-tooltip-control-color-hover-dark);
--cbp-tooltip-control-color-bg-hover: var(--cbp-tooltip-control-color-bg-hover-dark);
--cbp-tooltip-control-color-focus: var(--cbp-tooltip-control-color-focus-dark);
--cbp-tooltip-control-color-bg-focus: var(--cbp-tooltip-control-color-bg-focus-dark);
--cbp-tooltip-control-outline-focus: var(--cbp-tooltip-control-outline-focus-dark);
--cbp-tooltip-definition-color: var(--cbp-tooltip-definition-color-dark);
--cbp-tooltip-definition-color-hover: var(--cbp-tooltip-definition-color-hover-dark);
--cbp-tooltip-definition-color-focus: var(--cbp-tooltip-definition-color-focus-dark);
--cbp-tooltip-definition-outline-focus: var(--cbp-tooltip-definition-outline-focus-dark);
}
cbp-tooltip {
display: inline-flex;
align-items: center;
justify-content: center;
position: relative;
border-radius: var(--cbp-border-radius-soft);
padding: var(--cbp-space-1x);
outline-offset: calc(-1 * var(--cbp-space-1x));
--cbp-tooltip-placement-gap: var(--cbp-tooltip-gap);
--cbp-tooltip-placement-offset: var(--cbp-tooltip-offset);
--cbp-tooltip-gap: var(--cbp-space-4x, 1rem);
/** definition link*/
/** Alignment*/
}
cbp-tooltip[open] [role=tooltip] {
display: flex;
}
cbp-tooltip:hover {
color: var(--cbp-tooltip-control-color-hover);
background: var(--cbp-tooltip-control-color-bg-hover);
}
cbp-tooltip:focus-visible, cbp-tooltip:focus-within {
color: var(--cbp-tooltip-control-color-focus);
background: var(--cbp-tooltip-control-color-bg-focus);
outline: var(--cbp-tooltip-control-outline-focus);
}
cbp-tooltip[variant=definition] {
font-size: var(--cbp-font-size-body);
color: var(--cbp-tooltip-definition-color);
text-decoration: underline;
text-decoration-style: dotted;
cursor: pointer;
}
cbp-tooltip[variant=definition]:hover {
color: var(--cbp-tooltip-definition-color-hover);
background-color: transparent;
}
cbp-tooltip[variant=definition]:focus, cbp-tooltip[variant=definition]:focus-visible, cbp-tooltip[variant=definition]:focus-within {
color: var(--cbp-tooltip-definition-color-focus);
background-color: transparent;
outline: var(--cbp-tooltip-definition-outline-focus);
}
cbp-tooltip[alignment=top-left] {
--cbp-tooltip-placement-top: calc(0px - var(--cbp-tooltip-placement-gap, 5px));
--cbp-tooltip-placement-left: calc(0px + var(--cbp-tooltip-placement-offset, 0px));
--cbp-tooltip-placement-bottom: unset;
--cbp-tooltip-placement-transform-x: 0;
--cbp-tooltip-placement-transform-y: -100%;
--cbp-tooltip-caret-rotation: 315deg;
--cbp-tooltip-caret-top: calc(100% - var(--cbp-tooltip-caret-offset));
--cbp-tooltip-caret-left: calc(0% + var(--cbp-tooltip-caret-space));
}
cbp-tooltip[alignment=top-center] {
--cbp-tooltip-placement-top: calc(0% - var(--cbp-tooltip-placement-gap, 5px));
--cbp-tooltip-placement-left: 50%;
--cbp-tooltip-placement-bottom: unset;
--cbp-tooltip-placement-transform-x: -50%;
--cbp-tooltip-placement-transform-y: -100%;
--cbp-tooltip-caret-rotation: 315deg;
--cbp-tooltip-caret-top: calc(100% - var(--cbp-tooltip-caret-offset));
--cbp-tooltip-caret-left: calc(50% - var(--cbp-tooltip-caret-offset)) ;
}
cbp-tooltip[alignment=top-right] {
--cbp-tooltip-placement-top: calc(0px - var(--cbp-tooltip-placement-gap, 5px));
--cbp-tooltip-placement-left: calc(100% + var(--cbp-tooltip-placement-offset, 0px));
--cbp-tooltip-placement-bottom: unset;
--cbp-tooltip-placement-transform-x: -100%;
--cbp-tooltip-placement-transform-y: -100%;
--cbp-tooltip-caret-rotation: 315deg;
--cbp-tooltip-caret-top: calc(100% - var(--cbp-tooltip-caret-offset));
--cbp-tooltip-caret-left: calc(100% - (var(--cbp-tooltip-caret-size) + var(--cbp-tooltip-caret-space)));
}
cbp-tooltip[alignment=right-top] {
--cbp-tooltip-placement-top: calc(0px + var(--cbp-tooltip-placement-offset, 0px));
--cbp-tooltip-placement-left: calc(100% + var(--cbp-tooltip-placement-gap, 5px));
--cbp-tooltip-placement-bottom: unset;
--cbp-tooltip-placement-transform-x: 0;
--cbp-tooltip-placement-transform-y: 0%;
--cbp-tooltip-caret-rotation: 45deg;
--cbp-tooltip-caret-top: calc(0% + var(--cbp-tooltip-caret-space));
--cbp-tooltip-caret-left: calc(0% - var(--cbp-tooltip-caret-offset)) ;
}
cbp-tooltip[alignment=right-center] {
--cbp-tooltip-placement-top: 50%;
--cbp-tooltip-placement-left: calc(100% + var(--cbp-tooltip-placement-gap, 5px));
--cbp-tooltip-placement-bottom: unset;
--cbp-tooltip-placement-transform-x: 0;
--cbp-tooltip-placement-transform-y: -50%;
--cbp-tooltip-caret-rotation: 45deg;
--cbp-tooltip-caret-top: calc(50% - var(--cbp-tooltip-caret-offset));
--cbp-tooltip-caret-left: calc(0% - var(--cbp-tooltip-caret-offset)) ;
}
cbp-tooltip[alignment=right-bottom] {
--cbp-tooltip-placement-top: unset;
--cbp-tooltip-placement-left: calc(100% + var(--cbp-tooltip-placement-gap, 5px));
--cbp-tooltip-placement-bottom: 0%;
--cbp-tooltip-placement-transform-x: 0;
--cbp-tooltip-placement-transform-y: 0;
--cbp-tooltip-caret-rotation: 45deg;
--cbp-tooltip-caret-top: calc(100% - var(--cbp-tooltip-caret-size) - var(--cbp-tooltip-caret-space));
--cbp-tooltip-caret-left: calc(0% - var(--cbp-tooltip-caret-offset));
}
cbp-tooltip[alignment=bottom-left] {
--cbp-tooltip-placement-top: calc(100% + var(--cbp-tooltip-placement-gap, 5px));
--cbp-tooltip-placement-left: calc(0px + var(--cbp-tooltip-placement-offset, 0px));
--cbp-tooltip-placement-bottom: unset;
--cbp-tooltip-placement-transform-x: 0;
--cbp-tooltip-placement-transform-y: 0;
--cbp-tooltip-caret-rotation: 135deg;
--cbp-tooltip-caret-left: calc(0% + var(--cbp-tooltip-caret-space));
--cbp-tooltip-caret-top: calc(0% - var(--cbp-tooltip-caret-offset)) ;
}
cbp-tooltip[alignment=bottom-center] {
--cbp-tooltip-placement-top: calc(100% + var(--cbp-tooltip-placement-gap, 5px));
--cbp-tooltip-placement-left: 50%;
--cbp-tooltip-placement-bottom: unset;
--cbp-tooltip-placement-transform-x: -50%;
--cbp-tooltip-placement-transform-y: 0;
--cbp-tooltip-caret-rotation: 135deg;
--cbp-tooltip-caret-left: calc(50% - var(--cbp-tooltip-caret-offset));
--cbp-tooltip-caret-top: calc(0% - var(--cbp-tooltip-caret-offset)) ;
}
cbp-tooltip[alignment=bottom-right] {
--cbp-tooltip-placement-top: calc(100% + var(--cbp-tooltip-placement-gap, 5px));
--cbp-tooltip-placement-left: calc(100% + var(--cbp-tooltip-placement-offset, 0px));
--cbp-tooltip-placement-bottom: unset;
--cbp-tooltip-placement-transform-x: -100%;
--cbp-tooltip-placement-transform-y: 0;
--cbp-tooltip-caret-rotation: 135deg;
--cbp-tooltip-caret-left: calc(100% - (var(--cbp-tooltip-caret-size) + var(--cbp-tooltip-caret-space)));
--cbp-tooltip-caret-top: calc(0% - var(--cbp-tooltip-caret-offset)) ;
}
cbp-tooltip[alignment=left-top] {
--cbp-tooltip-placement-top: calc(0% + var(--cbp-tooltip-placement-offset, 0px));
--cbp-tooltip-placement-left: calc(0% - var(--cbp-tooltip-placement-gap, 5px));
--cbp-tooltip-placement-bottom: unset;
--cbp-tooltip-placement-transform-x: -100%;
--cbp-tooltip-placement-transform-y: 0%;
--cbp-tooltip-caret-rotation: 225deg;
--cbp-tooltip-caret-top: calc(0% + var(--cbp-tooltip-caret-space));
--cbp-tooltip-caret-left: calc(100% - var(--cbp-tooltip-caret-offset)) ;
}
cbp-tooltip[alignment=left-center] {
--cbp-tooltip-placement-top: 50%;
--cbp-tooltip-placement-left: calc(0% - var(--cbp-tooltip-placement-gap, 5px));
--cbp-tooltip-placement-bottom: unset;
--cbp-tooltip-placement-transform-x: -100%;
--cbp-tooltip-placement-transform-y: -50%;
--cbp-tooltip-caret-rotation: 225deg;
--cbp-tooltip-caret-top: calc(50% - var(--cbp-tooltip-caret-offset));
--cbp-tooltip-caret-left: calc(100% - var(--cbp-tooltip-caret-offset)) ;
}
cbp-tooltip[alignment=left-bottom] {
--cbp-tooltip-placement-top: unset;
--cbp-tooltip-placement-left: calc(0% - var(--cbp-tooltip-placement-gap, 5px));
--cbp-tooltip-placement-bottom: 0%;
--cbp-tooltip-placement-transform-x: -100%;
--cbp-tooltip-placement-transform-y: 0%;
--cbp-tooltip-caret-rotation: 225deg;
--cbp-tooltip-caret-top: calc(100% - var(--cbp-tooltip-caret-size) - var(--cbp-tooltip-caret-space));
--cbp-tooltip-caret-left: calc(100% - var(--cbp-tooltip-caret-offset));
}
cbp-tooltip div[role=tooltip] {
display: none;
position: absolute;
top: var(--cbp-tooltip-placement-top);
left: var(--cbp-tooltip-placement-left);
bottom: var(--cbp-tooltip-placement-bottom);
height: var(--tooltip-height, auto);
padding: var(--cbp-space-1x);
min-height: var(--cbp-space-11x);
width: max-content;
max-width: 33vw;
transform: translate(var(--cbp-tooltip-placement-transform-x, 0), var(--cbp-tooltip-placement-transform-y, 0));
border-style: solid;
border-width: 0px;
border-color: none;
border-radius: var(--cbp-border-radius-softer);
background-color: var(--cbp-tooltip-color-bg);
color: var(--cbp-tooltip-color);
font-size: var(--cbp-font-size-body);
font-weight: var(--cbp-font-weight-regular);
text-underline-offset: initial;
box-shadow: var(--cbp-shadow-level-1-center);
z-index: var(--cbp-z-index-level-1);
}
cbp-tooltip div[role=tooltip] > div {
padding: var(--cbp-space-1x);
}
cbp-tooltip div[role=tooltip] > div [slot=cbp-tooltip-content] {
line-height: var(--cbp-line-height-xs);
}
cbp-tooltip div[role=tooltip]::before {
content: "";
position: absolute;
display: var(--cbp-caret-display, block);
width: var(--cbp-tooltip-caret-size);
height: var(--cbp-tooltip-caret-size);
left: var(--cbp-tooltip-caret-left);
top: var(--cbp-tooltip-caret-top);
transform-origin: center;
transform: rotate(var(--cbp-tooltip-caret-rotation));
clip-path: polygon(8% 0, 100% 92%, 100% 100%, 0 100%, 0 0);
border: inherit;
background-color: inherit;
box-shadow: var(--cbp-shadow-level-1-center);
}