@gravity-ui/uikit
Version:
Gravity UI base styling and components
182 lines • 5.23 kB
CSS
.g-label {
--_--bg-color: none;
--_--bg-color-hover: none;
--_--text-color: none;
display: inline-flex;
align-items: center;
position: relative;
height: var(--_--height);
border-radius: var(--_--border-radius);
color: var(--_--text-color);
background-color: var(--_--bg-color);
transition-property: opacity, color, background-color;
transition-duration: 0.15s;
transition-timing-function: ease-in-out;
box-sizing: border-box;
/* make new stacking context to isolate z-indexes */
isolation: isolate;
}
.g-label__text {
font-family: var(--g-text-body-font-family);
font-weight: var(--g-text-body-font-weight);
font-size: var(--g-text-body-short-font-size);
line-height: var(--g-text-body-short-line-height);
display: flex;
align-items: baseline;
margin: 0 var(--_--margin-inline);
width: 100%;
text-align: center;
white-space: nowrap;
overflow: hidden;
}
.g-label__content, .g-label__key {
text-overflow: ellipsis;
overflow: hidden;
}
.g-label__value {
display: flex;
opacity: 0.7;
overflow: hidden;
}
.g-label__separator {
margin: 0 4px;
}
.g-label__main-button {
padding: 0;
font-family: var(--g-text-body-font-family);
font-size: inherit;
font-weight: var(--g-text-body-font-weight);
color: inherit;
background: none;
border: none;
outline: none;
cursor: pointer;
border-radius: inherit;
z-index: 1;
}
.g-label__main-button:empty {
position: absolute;
inset: 0;
}
.g-label__addon {
display: flex;
align-items: center;
justify-content: center;
width: var(--_--height);
height: var(--_--height);
border-radius: var(--_--border-radius);
}
.g-label__addon_side_start, .g-label__addon_side_end {
position: absolute;
inset-block-start: 0;
}
.g-label__addon_side_start {
inset-inline-start: 2px;
border-start-end-radius: 0;
border-end-end-radius: 0;
}
.g-label__addon_side_end {
inset-inline-end: 0;
border-start-start-radius: 0;
border-end-start-radius: 0;
}
.g-label__addon_type_button {
padding: 0;
font-family: var(--g-text-body-font-family);
font-size: inherit;
font-weight: var(--g-text-body-font-weight);
color: inherit;
background: none;
border: none;
outline: none;
cursor: pointer;
z-index: 2;
cursor: pointer;
color: var(--_--text-color);
background-color: transparent;
transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, transform 0.1s ease-out;
}
.g-label__addon_type_button:active {
transform: scale(0.96);
}
.g-label_size_xs {
--_--height: 20px;
--_--border-radius: var(--g-border-radius-xs);
--_--margin-inline: 8px;
--_--margin-addon-start: 24px;
--_--margin-addon-end: 22px;
}
.g-label_size_s {
--_--height: 24px;
--_--border-radius: var(--g-border-radius-s);
--_--margin-inline: 10px;
--_--margin-addon-start: 28px;
--_--margin-addon-end: 26px;
}
.g-label_size_m {
--_--height: 28px;
--_--border-radius: var(--g-border-radius-m);
--_--margin-inline: 12px;
--_--margin-addon-start: 32px;
--_--margin-addon-end: 32px;
}
.g-label_disabled {
opacity: 0.7;
pointer-events: none;
}
.g-label_interactive {
cursor: pointer;
}
.g-label_theme_normal {
--_--bg-color: var(--g-color-base-misc-light);
--_--bg-color-hover: var(--g-color-base-misc-light-hover);
--_--text-color: var(--g-color-text-misc-heavy);
}
.g-label_theme_success {
--_--bg-color: var(--g-color-base-positive-light);
--_--bg-color-hover: var(--g-color-base-positive-light-hover);
--_--text-color: var(--g-color-text-positive-heavy);
}
.g-label_theme_info {
--_--bg-color: var(--g-color-base-info-light);
--_--bg-color-hover: var(--g-color-base-info-light-hover);
--_--text-color: var(--g-color-text-info-heavy);
}
.g-label_theme_warning {
--_--bg-color: var(--g-color-base-warning-light);
--_--bg-color-hover: var(--g-color-base-warning-light-hover);
--_--text-color: var(--g-color-text-warning-heavy);
}
.g-label_theme_danger {
--_--bg-color: var(--g-color-base-danger-light);
--_--bg-color-hover: var(--g-color-base-danger-light-hover);
--_--text-color: var(--g-color-text-danger-heavy);
}
.g-label_theme_utility {
--_--bg-color: var(--g-color-base-utility-light);
--_--bg-color-hover: var(--g-color-base-utility-light-hover);
--_--text-color: var(--g-color-text-utility-heavy);
}
.g-label_theme_unknown {
--_--bg-color: var(--g-color-base-neutral-light);
--_--bg-color-hover: var(--g-color-base-neutral-light-hover);
--_--text-color: var(--g-color-text-complementary);
}
.g-label_theme_clear {
--_--bg-color: transparent;
--_--bg-color-hover: var(--g-color-base-simple-hover);
--_--text-color: var(--g-color-text-complementary);
box-shadow: inset 0 0 0 1px var(--g-color-line-generic);
}
.g-label:has(.g-label__addon_side_start) .g-label__text {
margin-inline-start: var(--_--margin-addon-start);
}
.g-label:has(.g-label__addon_side_end) .g-label__text {
margin-inline-end: var(--_--margin-addon-end);
}
.g-label_interactive:hover:not(:has(.g-label__addon_type_button:hover)), .g-label__addon_type_button:hover {
background-color: var(--_--bg-color-hover);
}
.g-label__main-button:focus-visible, .g-label__addon_type_button:focus-visible {
outline: 2px solid var(--g-color-line-focus);
}