@dnb/eufemia
Version:
DNB Eufemia Design System UI Library
424 lines • 17.9 kB
CSS
/*
* Input component
*
*/
/*
* Utilities
*/
.eufemia-scope--10_104_0 .dnb-input {
--input-font-size: var(--font-size-basis);
--input-font-size--small: var(--font-size-basis);
--input-font-size--medium: var(--font-size-basis);
--input-font-size--large: var(--font-size-medium);
--input-padding: 1rem;
--input-padding--small: 1rem;
--input-padding--medium: 1rem;
--input-padding--large: 1rem;
--input-height: 2rem;
--input-height--small: 1.5rem;
--input-height--medium: 2.5rem;
--input-height--large: 3rem;
--input-background-color: var(--color-white);
display: inline-flex;
align-items: center;
font-size: var(--input-font-small);
line-height: var(--input-height);
text-align: left;
}
.eufemia-scope--10_104_0 .dnb-input__inner {
display: inline-flex;
flex-direction: column;
width: auto;
}
.eufemia-scope--10_104_0 .dnb-input__shell {
position: relative;
display: flex;
align-items: center;
border: var(--input-border-width) solid var(--color-sea-green);
}
.eufemia-scope--10_104_0 .dnb-input__row {
display: inline-flex;
align-items: center;
}
.eufemia-scope--10_104_0 .dnb-input__input {
border: none;
outline: none;
word-break: normal;
position: relative;
z-index: 2;
}
.eufemia-scope--10_104_0 .dnb-input__input[disabled] {
-webkit-user-select: none;
user-select: none;
opacity: 1;
}
.eufemia-scope--10_104_0 .dnb-input__shell, .eufemia-scope--10_104_0 .dnb-input__input {
height: var(--input-height);
border-radius: var(--input-border-radius);
}
.eufemia-scope--10_104_0 .dnb-input__placeholder, .eufemia-scope--10_104_0 .dnb-input__input {
width: 100%;
padding-left: var(--input-padding);
padding-right: var(--input-padding);
}
.eufemia-scope--10_104_0 .dnb-input__placeholder, .eufemia-scope--10_104_0 .dnb-input__input, .eufemia-scope--10_104_0 .dnb-input input.dnb-input__input {
padding-top: 0;
padding-bottom: 0;
color: inherit;
background-color: transparent;
font-size: var(--input-font-size);
line-height: inherit;
}
.eufemia-scope--10_104_0 .dnb-input__placeholder {
pointer-events: none;
position: absolute;
z-index: 1;
top: 0;
left: 0;
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
}
.eufemia-scope--10_104_0 .dnb-input__border {
display: flex;
border-radius: var(--b-radius, var(--input-border-radius));
--border-color: var(--b-color, var(--input-border-color));
--border-width: var(--b-width, var(--input-border-width));
box-shadow: var(--b-inset, var(--input-border-inset, inset)) 0 0 0 var(--border-width) var(--border-color);
border-color: transparent;
}
.eufemia-scope--10_104_0 .dnb-input--disabled .dnb-input__border {
--border-color: var(--input-border-color--disabled);
--border-width: var(--input-border-width--disabled);
box-shadow: var(--input-border-inset--disabled, inset) 0 0 0 var(--border-width) var(--border-color);
border-color: transparent;
}
.eufemia-scope--10_104_0 .dnb-input__border:focus-within {
--b-color: var(--input-border-color--active);
--b-width: var(--input-border-width--active);
--b-inset: var(--input-border-inset--active);
--b-radius: var(--input-border-radius--active);
}
.eufemia-scope--10_104_0 .dnb-input__border:hover, .eufemia-scope--10_104_0 .dnb-input__border.hover {
--b-color: var(--input-border-color--hover);
--b-width: var(--input-border-width--hover);
--b-inset: var(--input-border-inset--hover);
}
.eufemia-scope--10_104_0 .dnb-input__border:has(.dnb-input__input:-webkit-autofill) {
--b-color: var(--input-border-color);
--b-inset: var(--input-border-inset--active);
}
.eufemia-scope--10_104_0 .dnb-input__border:has(.dnb-input__input:autofill) {
--b-color: var(--input-border-color);
--b-inset: var(--input-border-inset--active);
}
.eufemia-scope--10_104_0 .dnb-input__status--error .dnb-input__border:has(.dnb-input__input:-webkit-autofill) {
--b-color: var(--input-border-color__error);
}
.eufemia-scope--10_104_0 .dnb-input__status--error .dnb-input__border:has(.dnb-input__input:autofill) {
--b-color: var(--input-border-color__error);
}
.eufemia-scope--10_104_0 .dnb-input__status--error .dnb-input__border {
--b-color: var(--input-border-color__error);
--b-width: var(--input-border-width__error);
}
.eufemia-scope--10_104_0 .dnb-input__status--error .dnb-input__border:focus-within {
--b-color: var(--input-border-color__error);
--b-width: var(--input-border-width__error--active);
--b-inset: var(--input-border-inset--active);
--b-radius: var(--input-border-radius--active);
}
.eufemia-scope--10_104_0 .dnb-input__status--error .dnb-input__border:hover:has(.dnb-input__input:-webkit-autofill) {
--b-color: var(--input-border-color__error);
--b-width: var(--input-border-width__error--hover);
--b-inset: var(--input-border-inset--hover);
}
.eufemia-scope--10_104_0 .dnb-input__status--error .dnb-input__border:hover, .eufemia-scope--10_104_0 .dnb-input__status--error .dnb-input__border:hover:has(.dnb-input__input:autofill), .eufemia-scope--10_104_0 .dnb-input__status--error .dnb-input__border.hover {
--b-color: var(--input-border-color__error);
--b-width: var(--input-border-width__error--hover);
--b-inset: var(--input-border-inset--hover);
}
html[data-whatinput=keyboard] .eufemia-scope--10_104_0 .dnb-input__border:focus-within {
--b-color: var(--input-border-color--focus);
--b-width: var(--input-border-width--focus);
--b-inset: var(--input-border-inset--focus);
--b-radius: var(--input-border-radius--focus);
}
html[data-whatinput=keyboard] .eufemia-scope--10_104_0 .dnb-input__status--error .dnb-input__border:focus-within {
--b-color: var(--input-border-color__error--focus);
--b-width: var(--input-border-width--focus);
--b-inset: var(--input-border-inset--focus);
--b-radius: var(--input-border-radius--focus);
}
.eufemia-scope--10_104_0 .dnb-input input.dnb-input__input[type=file] {
line-height: calc(var(--input-height) - 2px);
}
.eufemia-scope--10_104_0 .dnb-input__input::-webkit-search-cancel-button {
display: none;
}
.eufemia-scope--10_104_0 .dnb-input__input::-ms-clear {
display: none;
}
.eufemia-scope--10_104_0 .dnb-input ::-webkit-file-upload-button {
cursor: pointer;
outline: none;
color: var(--color-sea-green);
}
.eufemia-scope--10_104_0 .dnb-input ::-webkit-file-upload-button:active, .eufemia-scope--10_104_0 .dnb-input ::-webkit-file-upload-button:hover {
color: var(--color-emerald-green);
}
.eufemia-scope--10_104_0 .dnb-input--has-submit-element .dnb-input__placeholder, .eufemia-scope--10_104_0 .dnb-input--has-submit-element .dnb-input__input, .eufemia-scope--10_104_0 .dnb-input--has-clear-button .dnb-input__placeholder, .eufemia-scope--10_104_0 .dnb-input--has-clear-button .dnb-input__input {
padding-right: calc(var(--input-padding) * 2.5);
}
.eufemia-scope--10_104_0 .dnb-input--password .dnb-input__placeholder, .eufemia-scope--10_104_0 .dnb-input--password .dnb-input__input {
margin-right: 2.5rem;
padding-right: 0;
}
.eufemia-scope--10_104_0 .dnb-input--password .dnb-input__placeholder::-ms-clear, .eufemia-scope--10_104_0 .dnb-input--password .dnb-input__input::-ms-clear {
display: none;
}
.eufemia-scope--10_104_0 .dnb-input--password .dnb-input__placeholder::-ms-reveal, .eufemia-scope--10_104_0 .dnb-input--password .dnb-input__input::-ms-reveal {
display: none;
}
.eufemia-scope--10_104_0 .dnb-input--password .dnb-input__placeholder {
padding-right: 4rem;
}
.eufemia-scope--10_104_0 .dnb-input--password .dnb-input__input {
font-family: var(--font-family-monospace);
}
.eufemia-scope--10_104_0 .dnb-input__suffix {
color: inherit;
}
.eufemia-scope--10_104_0 .dnb-input__submit-element {
z-index: 3;
margin-left: calc(var(--input-height) * -1);
line-height: var(--line-height-basis);
}
.eufemia-scope--10_104_0 .dnb-input__submit-element .dnb-button--input-button {
width: var(--input-height);
height: var(--input-height);
line-height: var(--input-height);
}
.eufemia-scope--10_104_0 .dnb-input__submit-button {
position: relative;
align-self: center; /* IE needs this to stay centered */
}
.eufemia-scope--10_104_0 .dnb-input__submit-button__button {
border-radius: 0 var(--input-border-radius) var(--input-border-radius) 0;
}
.eufemia-scope--10_104_0 .dnb-input > .dnb-form-label {
line-height: var(--line-height-basis);
}
@media screen and (max-width: 40em) {
.eufemia-scope--10_104_0 .dnb-input {
flex-wrap: wrap;
}
.eufemia-scope--10_104_0 .dnb-input > .dnb-form-label {
margin-bottom: 0.5rem;
margin-top: 0.5rem;
}
}
.eufemia-scope--10_104_0 .dnb-input:not(.dnb-input--vertical)[class*=__status] {
align-items: flex-start;
}
.eufemia-scope--10_104_0 .dnb-input:not(.dnb-input--vertical)[class*=__status] > .dnb-form-label {
margin-top: 0.25rem;
}
.eufemia-scope--10_104_0 .dnb-input--small {
line-height: var(--input-height--small);
}
.eufemia-scope--10_104_0 .dnb-input--small .dnb-input__shell,
.eufemia-scope--10_104_0 .dnb-input--small .dnb-input__input {
height: var(--input-height--small);
}
.eufemia-scope--10_104_0 .dnb-input--small .dnb-input__placeholder,
.eufemia-scope--10_104_0 .dnb-input--small .dnb-input__input {
padding-left: var(--input-padding--small);
padding-right: var(--input-padding--small);
font-size: var(--input-font-size--small);
}
.eufemia-scope--10_104_0 .dnb-input--small .dnb-input__submit-element {
margin-left: calc(var(--input-height--small) * -1);
}
.eufemia-scope--10_104_0 .dnb-input--small .dnb-input__submit-element .dnb-button--input-button {
width: var(--input-height--small);
height: var(--input-height--small);
line-height: var(--input-height--small);
}
.eufemia-scope--10_104_0 .dnb-input--small.dnb-input--has-submit-element .dnb-input__placeholder, .eufemia-scope--10_104_0 .dnb-input--small.dnb-input--has-submit-element .dnb-input__input, .eufemia-scope--10_104_0 .dnb-input--small.dnb-input--has-clear-button .dnb-input__placeholder, .eufemia-scope--10_104_0 .dnb-input--small.dnb-input--has-clear-button .dnb-input__input {
padding-right: calc(var(--input-padding--small) * 2);
}
.eufemia-scope--10_104_0 .dnb-input--medium {
line-height: var(--input-height--medium);
}
.eufemia-scope--10_104_0 .dnb-input--medium .dnb-input__shell,
.eufemia-scope--10_104_0 .dnb-input--medium .dnb-input__input {
height: var(--input-height--medium);
}
.eufemia-scope--10_104_0 .dnb-input--medium .dnb-input__placeholder,
.eufemia-scope--10_104_0 .dnb-input--medium .dnb-input__input {
padding-left: var(--input-padding--medium);
padding-right: var(--input-padding--medium);
font-size: var(--input-font-size--medium);
}
.eufemia-scope--10_104_0 .dnb-input--medium .dnb-input__submit-element {
margin-left: calc(var(--input-height--medium) * -1);
}
.eufemia-scope--10_104_0 .dnb-input--medium .dnb-input__submit-element .dnb-button--input-button {
width: var(--input-height--medium);
height: var(--input-height--medium);
line-height: var(--input-height--medium);
}
.eufemia-scope--10_104_0 .dnb-input--medium.dnb-input--has-submit-element .dnb-input__placeholder, .eufemia-scope--10_104_0 .dnb-input--medium.dnb-input--has-submit-element .dnb-input__input, .eufemia-scope--10_104_0 .dnb-input--medium.dnb-input--has-clear-button .dnb-input__placeholder, .eufemia-scope--10_104_0 .dnb-input--medium.dnb-input--has-clear-button .dnb-input__input {
padding-right: calc(var(--input-padding--medium) * 3);
}
.eufemia-scope--10_104_0 .dnb-input--large {
line-height: var(--input-height--large);
}
.eufemia-scope--10_104_0 .dnb-input--large .dnb-input__shell,
.eufemia-scope--10_104_0 .dnb-input--large .dnb-input__input {
height: var(--input-height--large);
}
.eufemia-scope--10_104_0 .dnb-input--large .dnb-input__placeholder,
.eufemia-scope--10_104_0 .dnb-input--large .dnb-input__input {
padding-left: var(--input-padding--large);
padding-right: var(--input-padding--large);
font-size: var(--input-font-size--large);
}
.eufemia-scope--10_104_0 .dnb-input--large .dnb-input__submit-element {
margin-left: calc(var(--input-height--large) * -1);
}
.eufemia-scope--10_104_0 .dnb-input--large .dnb-input__submit-element .dnb-button--input-button {
width: var(--input-height--large);
height: var(--input-height--large);
line-height: var(--input-height--large);
}
.eufemia-scope--10_104_0 .dnb-input--large.dnb-input--has-submit-element .dnb-input__placeholder, .eufemia-scope--10_104_0 .dnb-input--large.dnb-input--has-submit-element .dnb-input__input, .eufemia-scope--10_104_0 .dnb-input--large.dnb-input--has-clear-button .dnb-input__placeholder, .eufemia-scope--10_104_0 .dnb-input--large.dnb-input--has-clear-button .dnb-input__input {
padding-right: calc(var(--input-padding--large) * 3.5);
}
.eufemia-scope--10_104_0 .dnb-input--large.dnb-input--has-clear-button:not(.dnb-input--has-submit-element) .dnb-input__submit-element {
margin-left: calc(var(--input-height--large) - 0.5rem);
}
.eufemia-scope--10_104_0 .dnb-input__align--center .dnb-input__placeholder, .eufemia-scope--10_104_0 .dnb-input__align--center .dnb-input__input {
text-align: center;
}
.eufemia-scope--10_104_0 .dnb-input__align--right .dnb-input__placeholder, .eufemia-scope--10_104_0 .dnb-input__align--right .dnb-input__input {
text-align: right;
}
.eufemia-scope--10_104_0 .dnb-input--clear.dnb-input__submit-element {
opacity: 0;
transition: opacity 200ms ease-in-out;
}
.eufemia-scope--10_104_0 .dnb-input--clear.dnb-input__submit-element .dnb-button {
width: var(--input-height--small);
height: var(--input-height--small);
border-radius: var(--button-border-radius);
}
.eufemia-scope--10_104_0 .dnb-input--clear.dnb-input__submit-element .dnb-button .dnb-button__icon {
margin: auto;
}
html:not([data-whatintent=touch]) .eufemia-scope--10_104_0 .dnb-input--clear.dnb-input__submit-element .dnb-button:not(.dnb-button--has-text):hover[disabled] {
cursor: default;
}
.eufemia-scope--10_104_0 .dnb-input--small .dnb-input--clear.dnb-input__submit-element .dnb-button {
width: 1rem;
height: 1rem;
}
.eufemia-scope--10_104_0 .dnb-input--medium .dnb-input--clear.dnb-input__submit-element .dnb-button, .eufemia-scope--10_104_0 .dnb-input--large .dnb-input--clear.dnb-input__submit-element .dnb-button {
width: var(--input-height--small);
height: var(--input-height--small);
}
.eufemia-scope--10_104_0 .dnb-input[data-has-content=true] .dnb-input--clear {
opacity: 1;
}
.eufemia-scope--10_104_0 .dnb-input--has-submit-element .dnb-input--clear.dnb-input__submit-element {
margin-right: 2.5rem;
}
.eufemia-scope--10_104_0 .dnb-input--small.dnb-input--has-submit-element .dnb-input--clear.dnb-input__submit-element {
margin-right: 2rem;
}
.eufemia-scope--10_104_0 .dnb-input--medium.dnb-input--has-submit-element .dnb-input--clear.dnb-input__submit-element {
margin-right: 3rem;
}
.eufemia-scope--10_104_0 .dnb-input--large.dnb-input--has-submit-element .dnb-input--clear.dnb-input__submit-element {
margin-right: 3.5rem;
}
.eufemia-scope--10_104_0 .dnb-input__inner > .dnb-form-status {
order: 2;
margin-top: 0.5rem;
}
.eufemia-scope--10_104_0 .dnb-input--vertical {
display: flex;
flex-direction: column;
align-items: flex-start;
}
.eufemia-scope--10_104_0 .dnb-input--stretch {
display: flex;
flex-grow: 1;
}
.eufemia-scope--10_104_0 .dnb-input--stretch .dnb-input__inner {
flex-grow: 1;
}
.eufemia-scope--10_104_0 .dnb-input--stretch .dnb-input__inner, .eufemia-scope--10_104_0 .dnb-input--stretch .dnb-input__shell {
width: 100%;
}
.eufemia-scope--10_104_0 .dnb-input--stretch .dnb-form-label + .dnb-input__inner {
width: auto;
}
.eufemia-scope--10_104_0 .dnb-input--vertical.dnb-input--stretch .dnb-input__inner {
width: 100%;
}
.eufemia-scope--10_104_0 .dnb-form-row--horizontal .dnb-input--stretch {
width: 100%;
}
.eufemia-scope--10_104_0 .dnb-input__icon {
order: 0;
position: absolute;
z-index: 2;
left: 1rem;
right: auto;
top: 0;
bottom: 0;
margin: auto;
}
.eufemia-scope--10_104_0 .dnb-input--icon-position-right .dnb-input__icon {
order: 1;
left: auto;
right: 1rem;
}
.eufemia-scope--10_104_0 .dnb-input--icon-position-left.dnb-input--has-icon .dnb-input__input, .eufemia-scope--10_104_0 .dnb-input--icon-position-left.dnb-input--has-icon .dnb-input__placeholder {
padding-left: 2.5rem;
}
.eufemia-scope--10_104_0 .dnb-input--icon-position-right.dnb-input--has-icon .dnb-input__input, .eufemia-scope--10_104_0 .dnb-input--icon-position-right.dnb-input--has-icon .dnb-input__placeholder {
padding-right: 2.5rem;
}
.eufemia-scope--10_104_0 .dnb-input--icon-size-medium.dnb-input--icon-position-left.dnb-input--has-icon .dnb-input__input, .eufemia-scope--10_104_0 .dnb-input--icon-size-medium.dnb-input--icon-position-left.dnb-input--has-icon .dnb-input__placeholder {
padding-left: 3rem;
}
.eufemia-scope--10_104_0 .dnb-input--icon-size-medium.dnb-input--icon-position-right.dnb-input--has-icon .dnb-input__input, .eufemia-scope--10_104_0 .dnb-input--icon-size-medium.dnb-input--icon-position-right.dnb-input--has-icon .dnb-input__placeholder {
padding-right: 3rem;
}
html[data-visual-test] .eufemia-scope--10_104_0 .dnb-input__input {
caret-color: var(--color-white);
}
.eufemia-scope--10_104_0 .dnb-input[data-input-state=focus] .dnb-input__placeholder {
display: none;
}
.eufemia-scope--10_104_0 .dnb-input--keep-placeholder[data-input-state=focus] .dnb-input__placeholder {
display: block;
color: var(--color-black-20);
}
@media screen and (max-width: 40em) {
.eufemia-scope--10_104_0 .dnb-responsive-component .dnb-input {
display: flex;
flex-direction: column;
align-items: flex-start;
margin-bottom: 0.5rem;
}
.eufemia-scope--10_104_0 .dnb-responsive-component .dnb-input__row {
align-items: flex-start;
}
.eufemia-scope--10_104_0 .dnb-responsive-component .dnb-input > .dnb-form-label {
margin-bottom: 0.5rem;
}
}