UNPKG

@qvant/qui-max

Version:

A Vue 3 Design system for Web.

124 lines 4.14 kB
.q-input { --field-color-base: var(--color-primary-black); --field-color-placeholder: rgb(var(--color-rgb-gray) / 32%); --field-color-disabled: rgb(var(--color-rgb-gray) / 64%); --field-icon-color-base: var(--color-primary-blue); --field-icon-color-hover: var(--color-primary-black); --field-icon-color-inactive: rgb(var(--color-rgb-gray) / 64%); --field-background-color-base: var(--color-tertiary-gray-light); --field-background-color-hover: var(--color-tertiary-gray); --field-background-color-focus: var(--color-tertiary-gray-ultra-light); --field-background-color-disabled: var(--color-tertiary-gray); --field-box-shadow-base: -1px -1px 3px rgb(var(--color-rgb-white) / 25%), 1px 1px 3px rgb(var(--color-rgb-blue) / 40%), 4px 4px 8px rgb(var(--color-rgb-blue) / 40%), -4px -4px 12px var(--color-tertiary-white); --field-box-shadow-hover: -1px -1px 4px rgb(var(--color-rgb-white) / 25%), 1px 1px 4px rgb(var(--color-rgb-blue) / 40%), 4px 4px 8px rgb(var(--color-rgb-blue) / 40%), -4px -4px 8px rgb(var(--color-rgb-white) / 80%); --field-box-shadow-focus: -1px -1px 3px rgb(var(--color-rgb-white) / 25%), 1px 1px 3px rgb(var(--color-rgb-blue) / 40%), inset -1px -1px 1px rgb(var(--color-rgb-white) / 70%), inset 1px 1px 2px rgb(var(--color-rgb-blue) / 20%); --field-box-shadow-disabled: -1px -1px 3px rgb(var(--color-rgb-white) / 25%), 1px 1px 3px rgb(var(--color-rgb-blue) / 40%); position: relative; display: inline-block; width: 100%; height: 40px; } .q-input__inner { display: inline-block; width: 100%; height: 40px; padding: 0 16px; font-size: var(--font-size-base); font-weight: var(--font-weight-base); line-height: var(--line-height-base); color: var(--field-color-base); background-color: var(--field-background-color-base); border: none; border-radius: var(--border-radius-base); box-shadow: var(--field-box-shadow-base); appearance: textfield; /** disable default clear on IE */ } .q-input__inner::-webkit-outer-spin-button, .q-input__inner::-webkit-inner-spin-button { margin: 0; appearance: none; } .q-input__inner::placeholder, .q-input__inner:placeholder-shown { color: var(--field-color-placeholder); text-overflow: ellipsis; opacity: 1; } .q-input__inner::-ms-reveal, .q-input__inner::-ms-clear { display: none; width: 0; height: 0; } .q-input__inner:focus { outline: none; } .q-input_focused .q-input__inner, .q-input__inner.focus-visible { background-color: var(--field-background-color-focus); box-shadow: var(--field-box-shadow-focus); } .q-input__inner:hover { background-color: var(--field-background-color-hover); box-shadow: var(--field-box-shadow-hover); } .q-input_disabled .q-input__inner { padding-right: 40px; color: var(--field-color-disabled); cursor: not-allowed; background-color: var(--field-background-color-disabled); box-shadow: var(--field-box-shadow-disabled); } .q-input_suffix .q-input__inner { padding-right: 40px; } .q-form-item_is-error .q-input__inner, .q-form-item_is-error .q-input__inner.focus-visible { padding-left: 15px; border: var(--border-error); } .q-input__suffix { position: absolute; top: 0; right: 0; width: 40px; height: 100%; text-align: center; pointer-events: none; transition: all 0.3s; } .q-input__icon { width: 40px; font-size: 24px; line-height: 40px; color: var(--field-icon-color-inactive); text-align: center; } .q-input__icon:not(:last-child) { display: none; } .q-input__icon.q-icon-close, .q-input__icon.q-icon-eye, .q-input__icon.q-icon-eye-close { color: var(--field-icon-color-base); pointer-events: all; cursor: pointer; } .q-input__icon.q-icon-close:hover, .q-input__icon.q-icon-close.focus-visible, .q-input__icon.q-icon-eye:hover, .q-input__icon.q-icon-eye.focus-visible, .q-input__icon.q-icon-eye-close:hover, .q-input__icon.q-icon-eye-close.focus-visible { color: var(--field-icon-color-hover); } .q-input__suffix-slot { pointer-events: all; } .q-input__count { position: absolute; top: -24px; right: 0; margin-bottom: 2px; font-size: 10px; text-align: right; }