UNPKG

@gravity-ui/uikit

Version:

Gravity UI base styling and components

359 lines 12.6 kB
.g-text-input { --_--text-color: var(--g-color-text-primary); --_--label-color: inherit; --_--placeholder-color: var(--g-color-text-hint); --_--background-color: transparent; --_--border-width: 1px; --_--focus-outline-color: var(--g-text-input-focus-outline-color); display: inline-block; width: 100%; position: relative; } .g-text-input__content { box-sizing: border-box; overflow: hidden; display: flex; width: 100%; background-color: var(--g-text-input-background-color, var(--_--background-color)); border-width: var(--g-text-input-border-width, var(--_--border-width)); border-style: solid; border-color: var(--g-text-input-border-color, var(--_--border-color)); color: var(--g-text-input-text-color, var(--_--text-color)); } .g-text-input__content:hover { border-color: var(--g-text-input-border-color-hover, var(--_--border-color-hover)); } .g-text-input__content:focus-within { border-color: var(--g-text-input-border-color-active, var(--_--border-color-active)); outline: 2px solid var(--g-text-input-focus-outline-color, var(--_--focus-outline-color)); outline-offset: -1px; } .g-text-input__control { box-sizing: border-box; display: inline-block; flex-grow: 1; vertical-align: top; position: relative; margin: 0; padding: 0; width: 100%; font-weight: var(--g-text-body-font-weight); font-family: var(--g-text-body-font-family); color: inherit; background-color: transparent; border: none; height: var(--g-text-input-height); } .g-text-input__control::placeholder { color: var(--g-text-input-placeholder-color, var(--_--placeholder-color)); overflow: hidden; white-space: nowrap; } .g-text-input__control:focus { outline: none; } .g-text-input__control[type=number] { appearance: textfield; } .g-text-input__label { position: absolute; box-sizing: border-box; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; z-index: 1; color: var(--g-text-input-label-color, var(--_--label-color)); } .g-text-input__clear { flex-shrink: 0; margin: auto 0; } .g-text-input__clear_size_s, .g-text-input__clear_size_m { margin-inline-end: 1px; } .g-text-input__clear_size_l, .g-text-input__clear_size_xl { margin-inline-end: 2px; } .g-text-input__error-icon { box-sizing: content-box; color: var(--g-color-text-danger); padding-block: var(--_--error-icon-padding-block); padding-inline: var(--_--error-icon-padding-inline); } .g-text-input__additional-content { display: flex; align-items: center; } .g-text-input_size_s { --_--error-icon-padding-block: 5px; --_--error-icon-padding-inline: 0 5px; --_--border-radius: var(--g-border-radius-s); } .g-text-input_size_s .g-text-input__control { --_--input-control-border-width: var( --g-text-input-border-width, var(--g-text-area-border-width, 1px) ); 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); height: calc(24px - var(--_--input-control-border-width) * 2); padding: 3px 8px; } .g-text-input_size_s .g-text-input__label { 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); padding-block: 3px; padding-inline: 8px 4px; font-weight: var(--g-text-accent-font-weight); } .g-text-input_size_s.g-text-input_has-start-content .g-text-input__label { padding-inline-start: 2px; } .g-text-input_size_s .g-text-input__additional-content { height: 22px; } .g-text-input_size_s .g-text-input__additional-content_placement_start { padding-inline-start: 1px; } .g-text-input_size_s .g-text-input__additional-content_placement_end { padding-inline-end: 1px; } .g-text-input_size_m { --_--error-icon-padding-block: 5px; --_--error-icon-padding-inline: 0 5px; --_--border-radius: var(--g-border-radius-m); } .g-text-input_size_m .g-text-input__control { --_--input-control-border-width: var( --g-text-input-border-width, var(--g-text-area-border-width, 1px) ); 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); height: calc(28px - var(--_--input-control-border-width) * 2); padding: 5px 8px; } .g-text-input_size_m .g-text-input__label { 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); padding-block: 5px; padding-inline: 8px 4px; font-weight: var(--g-text-accent-font-weight); } .g-text-input_size_m.g-text-input_has-start-content .g-text-input__label { padding-inline-start: 2px; } .g-text-input_size_m .g-text-input__additional-content { height: 26px; } .g-text-input_size_m .g-text-input__additional-content_placement_start { padding-inline-start: 1px; } .g-text-input_size_m .g-text-input__additional-content_placement_end { padding-inline-end: 1px; } .g-text-input_size_l { --_--error-icon-padding-block: 9px; --_--error-icon-padding-inline: 0 9px; --_--border-radius: var(--g-border-radius-l); } .g-text-input_size_l .g-text-input__control { --_--input-control-border-width: var( --g-text-input-border-width, var(--g-text-area-border-width, 1px) ); 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); height: calc(36px - var(--_--input-control-border-width) * 2); padding: 9px 12px; } .g-text-input_size_l .g-text-input__label { 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); padding-block: 9px; padding-inline: 12px 4px; font-weight: var(--g-text-accent-font-weight); } .g-text-input_size_l.g-text-input_has-start-content .g-text-input__label { padding-inline-start: 3px; } .g-text-input_size_l .g-text-input__additional-content { height: 34px; } .g-text-input_size_l .g-text-input__additional-content_placement_start { padding-inline-start: 3px; } .g-text-input_size_l .g-text-input__additional-content_placement_end { padding-inline-end: 3px; } .g-text-input_size_xl { --_--error-icon-padding-block: 13px; --_--error-icon-padding-inline: 0 13px; --_--border-radius: var(--g-border-radius-xl); } .g-text-input_size_xl .g-text-input__control { --_--input-control-border-width: var( --g-text-input-border-width, var(--g-text-area-border-width, 1px) ); font-family: var(--g-text-body-font-family); font-weight: var(--g-text-body-font-weight); font-size: var(--g-text-body-2-font-size); line-height: var(--g-text-body-2-line-height); height: calc(44px - var(--_--input-control-border-width) * 2); padding: 11px 12px; } .g-text-input_size_xl .g-text-input__label { font-family: var(--g-text-body-font-family); font-weight: var(--g-text-body-font-weight); font-size: var(--g-text-body-2-font-size); line-height: var(--g-text-body-2-line-height); padding-block: 11px; padding-inline: 12px 4px; font-weight: var(--g-text-accent-font-weight); } .g-text-input_size_xl.g-text-input_has-start-content .g-text-input__label { padding-inline-start: 3px; } .g-text-input_size_xl .g-text-input__additional-content { height: 42px; } .g-text-input_size_xl .g-text-input__additional-content_placement_start { padding-inline-start: 3px; } .g-text-input_size_xl .g-text-input__additional-content_placement_end { padding-inline-end: 3px; } .g-text-input_view_normal { --_--border-color: var(--g-color-line-generic); --_--border-color-hover: var(--g-color-line-generic-hover); --_--border-color-active: var(--g-color-line-generic-active); } .g-text-input_view_clear { --_--border-color: transparent; --_--border-color-hover: transparent; --_--border-color-active: transparent; --_--border-radius: 0; } .g-text-input_view_clear .g-text-input__content { border-inline: 0; } .g-text-input_view_clear .g-text-input__control { padding-inline: 0; } .g-text-input.g-text-input_pin_round-round .g-text-input__content { border-radius: var(--g-text-input-border-radius, var(--_--border-radius)); } .g-text-input.g-text-input_pin_brick-brick .g-text-input__content { border-radius: 0; } .g-text-input.g-text-input_pin_clear-clear .g-text-input__content { border-radius: 0; border-inline: 0; } .g-text-input.g-text-input_pin_circle-circle .g-text-input__content { border-radius: 100px; } .g-text-input.g-text-input_pin_round-brick .g-text-input__content { border-start-start-radius: var(--g-text-input-border-radius, var(--_--border-radius)); border-start-end-radius: 0; border-end-start-radius: var(--g-text-input-border-radius, var(--_--border-radius)); border-end-end-radius: 0; } .g-text-input.g-text-input_pin_brick-round .g-text-input__content { border-start-start-radius: 0; border-start-end-radius: var(--g-text-input-border-radius, var(--_--border-radius)); border-end-start-radius: 0; border-end-end-radius: var(--g-text-input-border-radius, var(--_--border-radius)); } .g-text-input.g-text-input_pin_round-clear .g-text-input__content { border-start-start-radius: var(--g-text-input-border-radius, var(--_--border-radius)); border-start-end-radius: 0; border-end-start-radius: var(--g-text-input-border-radius, var(--_--border-radius)); border-end-end-radius: 0; border-inline-end: 0; } .g-text-input.g-text-input_pin_clear-round .g-text-input__content { border-start-start-radius: 0; border-start-end-radius: var(--g-text-input-border-radius, var(--_--border-radius)); border-end-start-radius: 0; border-end-end-radius: var(--g-text-input-border-radius, var(--_--border-radius)); border-inline-start: 0; } .g-text-input.g-text-input_pin_brick-clear .g-text-input__content { border-radius: 0; border-inline-end: 0; } .g-text-input.g-text-input_pin_clear-brick .g-text-input__content { border-radius: 0; border-inline-start: 0; } .g-text-input.g-text-input_pin_circle-brick .g-text-input__content { border-start-start-radius: 100px; border-start-end-radius: 0; border-end-start-radius: 100px; border-end-end-radius: 0; } .g-text-input.g-text-input_pin_brick-circle .g-text-input__content { border-start-start-radius: 0; border-start-end-radius: 100px; border-end-start-radius: 0; border-end-end-radius: 100px; } .g-text-input.g-text-input_pin_circle-clear .g-text-input__content { border-start-start-radius: 100px; border-start-end-radius: 0; border-end-start-radius: 100px; border-end-end-radius: 0; border-inline-end: 0; } .g-text-input.g-text-input_pin_clear-circle .g-text-input__content { border-start-start-radius: 0; border-start-end-radius: 100px; border-end-start-radius: 0; border-end-end-radius: 100px; border-inline-start: 0; } .g-text-input_disabled { --_--text-color: var(--g-color-text-hint); --_--background-color: var(--g-color-base-generic-accent-disabled); --_--border-color: transparent; --_--border-color-hover: transparent; --_--border-color-active: transparent; } .g-text-input_has-scrollbar .g-text-input__clear { inset-inline-end: var(--g-scrollbar-width); } .g-text-input_has-start-content .g-text-input__control { padding-inline-start: 2px; } .g-text-input_has-end-content { --_--error-icon-padding-inline: 0; } .g-text-input_has-end-content .g-text-input__control { padding-inline-end: 2px; } .g-text-input_state_error.g-text-input_view_normal .g-text-input__content, .g-text-input_state_error.g-text-input_view_normal .g-text-input__content:hover, .g-text-input_state_error.g-text-input_view_normal .g-text-input__content:focus-within { border-color: var(--g-color-line-danger); } .g-text-input_state_error.g-text-input_view_normal .g-text-input__content:focus-within { --_--focus-outline-color: var(--g-color-line-danger); } .g-text-input_state_error.g-text-input_view_clear .g-text-input__content, .g-text-input_state_error.g-text-input_view_clear .g-text-input__content:hover, .g-text-input_state_error.g-text-input_view_clear .g-text-input__content:focus-within { border-block-end: 1px solid var(--g-color-line-danger); } .g-text-input_state_error.g-text-input_view_clear .g-text-input__content:focus-within { --_--focus-outline-color: var(--g-color-line-danger); }