UNPKG

@esri/calcite-components

Version:

Web Components for Esri's Calcite Design System.

483 lines (435 loc) • 9.56 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. */ :host { /* Base ":host" styles for the component */ box-sizing: border-box; background-color: var(--calcite-ui-foreground-1); color: var(--calcite-ui-text-2); font-size: var(--calcite-font-size--1); } :host * { box-sizing: border-box; } :host { /* Component spacing variables */ --calcite-icon-size: 1rem; --calcite-spacing-eighth: 0.125rem; --calcite-spacing-quarter: 0.25rem; --calcite-spacing-half: 0.5rem; --calcite-spacing-three-quarters: 0.75rem; --calcite-spacing: 1rem; --calcite-spacing-plus-quarter: 1.25rem; --calcite-spacing-plus-half: 1.5rem; --calcite-spacing-double: 2rem; --calcite-menu-min-width: 10rem; --calcite-header-min-height: 3rem; --calcite-footer-min-height: 3rem; } :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; } /** * CSS Custom Properties * * These properties can be overridden using the component's tag as selector. * * @prop --calcite-block-padding: Specifies the padding of the block `default` slot. */ :host { display: flex; flex-shrink: 0; flex-grow: 0; flex-direction: column; border-width: 0px; border-block-end-width: 1px; border-style: solid; border-color: var(--calcite-ui-border-3); padding: 0px; transition-property: margin; transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); transition-duration: 150ms; transition-timing-function: cubic-bezier(0.215, 0.440, 0.420, 0.880); flex-basis: auto; } :host([disabled]) ::slotted([calcite-hydrated][disabled]), :host([disabled]) [calcite-hydrated][disabled] { /* prevent opacity stacking */ opacity: 1; } @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 */ /* Shared styles for header elements */ .header { margin: 0px; display: flex; align-content: space-between; align-items: center; fill: var(--calcite-ui-text-2); color: var(--calcite-ui-text-2); } .heading { margin: 0px; padding: 0px; font-weight: var(--calcite-font-weight-medium); } .header .heading { flex: 1 1 auto; padding: 0.5rem; } .header { justify-content: flex-start; padding: 0px; } .header, .toggle { grid-area: header; } .header-container { display: grid; align-items: stretch; grid-template: auto/auto 1fr auto auto; grid-template-areas: "handle header control menu"; grid-column: header-start/menu-end; grid-row: 1/2; } .toggle { margin: 0px; display: flex; cursor: pointer; flex-wrap: nowrap; align-items: center; justify-content: space-between; border-style: none; padding: 0px; font-family: inherit; outline-color: transparent; text-align: initial; background-color: transparent; } .toggle:hover { background-color: var(--calcite-ui-foreground-2); } .toggle: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 ) ) ); } calcite-loader[inline] { grid-area: control; align-self: center; } calcite-handle { grid-area: handle; } .title { margin: 0px; padding: 0.75rem; } .header .title .heading { padding: 0px; font-size: var(--calcite-font-size--1); font-weight: var(--calcite-font-weight-medium); line-height: 1.25; color: var(--calcite-ui-text-2); transition-property: color; transition-duration: 150ms; transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); word-wrap: break-word; word-break: break-word; } .description { margin-block-start: 0.125rem; padding: 0px; font-size: var(--calcite-font-size--2); line-height: 1.375; color: var(--calcite-ui-text-3); word-wrap: break-word; word-break: break-word; } .icon { display: flex; margin-inline-start: 0.75rem; margin-inline-end: 0px; } .status-icon.valid { color: var(--calcite-ui-success); } .status-icon.invalid { color: var(--calcite-ui-danger); } .status-icon.loading { animation: spin calc(var(--calcite-internal-animation-timing-slow) / var(--calcite-internal-duration-factor) * 2 / var(--calcite-internal-duration-factor)) linear infinite; } @keyframes spin { 0% { transform: rotate(0deg); } 50% { transform: rotate(180deg); } 100% { transform: rotate(360deg); } } .toggle-icon { margin-block: 0.75rem; align-self: center; justify-self: end; color: var(--calcite-ui-text-3); transition-property: color; transition-duration: 150ms; transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); margin-inline-end: 1rem; margin-inline-start: auto; } .toggle:hover .toggle-icon { color: var(--calcite-ui-text-1); } .container { position: relative; display: flex; block-size: 100%; flex-direction: column; } .content { position: relative; flex: 1 1 0%; } @keyframes in { 0% { opacity: 0; } 100% { opacity: 1; } } .content { animation: in var(--calcite-internal-animation-timing-slow) ease-in-out; padding-block: var(--calcite-block-padding, 0.5rem); padding-inline: var(--calcite-block-padding, 0.625rem); } .control-container { margin: 0px; display: flex; grid-area: control; } calcite-action-menu { grid-area: menu; } :host([open]) { margin-block: 0.5rem; } :host([open]) .header .title .heading { color: var(--calcite-ui-text-1); }