UNPKG

@esri/calcite-components

Version:

Web Components for Esri's Calcite Design System.

339 lines (305 loc) • 6.8 kB
/* mixins & extensions */ @keyframes in { 0% { opacity: 0; } 100% { opacity: 1; } } @keyframes in-down { 0% { opacity: 0; transform: translate3D(0, -5px, 0); } 100% { opacity: 1; transform: translate3D(0, 0, 0); } } @keyframes in-up { 0% { opacity: 0; transform: translate3D(0, 5px, 0); } 100% { opacity: 1; transform: translate3D(0, 0, 0); } } @keyframes in-right { 0% { opacity: 0; transform: translate3D(-5px, 0, 0); } 100% { opacity: 1; transform: translate3D(0, 0, 0); } } @keyframes in-left { 0% { opacity: 0; transform: translate3D(5px, 0, 0); } 100% { opacity: 1; transform: translate3D(0, 0, 0); } } @keyframes in-scale { 0% { opacity: 0; transform: scale3D(0.95, 0.95, 1); } 100% { opacity: 1; transform: scale3D(1, 1, 1); } } :root { --calcite-animation-timing: calc(150ms * var(--calcite-internal-duration-factor)); --calcite-internal-duration-factor: var(--calcite-duration-factor, 1); --calcite-internal-animation-timing-fast: calc(100ms * var(--calcite-internal-duration-factor)); --calcite-internal-animation-timing-medium: calc(200ms * var(--calcite-internal-duration-factor)); --calcite-internal-animation-timing-slow: calc(300ms * var(--calcite-internal-duration-factor)); } .calcite-animate { opacity: 0; animation-fill-mode: both; animation-duration: var(--calcite-animation-timing); } .calcite-animate__in { animation-name: in; } .calcite-animate__in-down { animation-name: in-down; } .calcite-animate__in-up { animation-name: in-up; } .calcite-animate__in-right { animation-name: in-right; } .calcite-animate__in-left { animation-name: in-left; } .calcite-animate__in-scale { animation-name: in-scale; } @media (prefers-reduced-motion: reduce) { :root { --calcite-internal-duration-factor: 0.01; } } /* helper to properly scale internal durations */ /** * Currently only used in Checkbox. */ :root { --calcite-floating-ui-transition: var(--calcite-animation-timing); --calcite-floating-ui-z-index: var(--calcite-app-z-index-dropdown); } :host([hidden]) { display: none; } :host([disabled]) { cursor: default; -webkit-user-select: none; user-select: none; opacity: var(--calcite-ui-opacity-disabled); } :host([disabled]) *, :host([disabled]) ::slotted(*) { pointer-events: none; } :host { position: relative; display: inline-block; block-size: 100%; inline-size: 100%; } textarea { position: relative; margin: 0px; box-sizing: border-box; display: block; inline-size: 100%; border-width: 1px; border-color: var(--calcite-ui-border-input); background-color: var(--calcite-ui-foreground-1); font-family: var(--calcite-sans-family); color: var(--calcite-ui-text-1); min-inline-size: 12rem; border-block-end: 1px solid var(--calcite-ui-border-3); } @media screen and (max-width: 480px) { textarea { resize: none; } } textarea:focus { outline: 2px solid var(--calcite-ui-focus-color, var(--calcite-ui-brand)); outline-offset: calc( -2px * calc( 1 - 2 * clamp( 0, var(--calcite-ui-focus-offset-invert), 1 ) ) ); } textarea.text-area--invalid { border-width: 1px; border-block-end-width: 1px; border-style: solid; border-color: var(--calcite-ui-danger); } textarea.text-area--invalid:focus { outline: 2px solid var(--calcite-ui-danger); outline-offset: calc( -2px * calc( 1 - 2 * clamp( 0, var(--calcite-ui-focus-offset-invert), 1 ) ) ); } textarea.footer--slotted { min-inline-size: 18rem; } .footer { box-sizing: border-box; display: flex; align-items: center; border-width: 1px; border-block-start-width: 0px; border-style: solid; border-color: var(--calcite-ui-border-input); background-color: var(--calcite-ui-foreground-1); } .character-limit { display: flex; align-items: center; justify-content: flex-end; white-space: nowrap; font-weight: var(--calcite-font-weight-normal); color: var(--calcite-ui-text-2); } .character--over-limit { font-weight: var(--calcite-font-weight-bold); color: var(--calcite-ui-danger); } :host([resize=none]) textarea { resize: none; } :host([resize=horizontal]) textarea { resize: horizontal; } :host([resize=vertical]) textarea { resize: vertical; } :host([scale=s]) { font-size: var(--calcite-font-size--2); } :host([scale=s]) .footer { padding-block: 0.25rem; padding-inline: 0.5rem; min-block-size: 1.75rem; } :host([scale=s]) textarea { padding-block: 0.25rem; padding-inline: 0.5rem; } :host([scale=s]) textarea, :host([scale=s]) .footer, :host([scale=s]) .character-limit { padding-inline-start: 0.5rem; font-size: var(--calcite-font-size--2); } :host([scale=m]) textarea { padding-block: 0.5rem; padding-inline: 0.75rem; } :host([scale=m]) .footer { padding-block: 0.5rem; padding-inline: 0.75rem; min-block-size: 2.25rem; } :host([scale=m]) textarea, :host([scale=m]) .footer, :host([scale=m]) .character-limit { padding-inline-start: 0.75rem; font-size: var(--calcite-font-size--1); } :host([scale=l]) { font-size: var(--calcite-font-size-0); } :host([scale=l]) textarea { padding-block: 0.75rem; padding-inline: 1rem; } :host([scale=l]) .footer { padding-block: 0.75rem; padding-inline: 1rem; min-block-size: 2.75rem; } :host([scale=l]) textarea, :host([scale=l]) .footer, :host([scale=l]) .character-limit { padding-inline-start: 1rem; font-size: var(--calcite-font-size-0); } .readonly { background-color: var(--calcite-ui-background); font-weight: var(--calcite-font-weight-medium); } :host([disabled]) textarea, :host([disabled]) footer { opacity: 0.5; } .border--color { border-block-end-width: 1px; border-color: var(--calcite-ui-border-input); } .border--color:focus { border-block-end-width: 2px; } textarea.block-size--full { block-size: 100%; } .content, .hide { display: none; } .container { display: flex; inline-size: 100%; justify-content: space-between; } .footer--end-only { justify-content: flex-end; } ::slotted(input[slot=hidden-form-input]) { margin: 0 !important; opacity: 0 !important; outline: none !important; padding: 0 !important; position: absolute !important; inset: 0 !important; transform: none !important; -webkit-appearance: none !important; z-index: -1 !important; } :host([disabled]) ::slotted([calcite-hydrated][disabled]), :host([disabled]) [calcite-hydrated][disabled] { /* prevent opacity stacking */ opacity: 1; }